diff --git a/build/test.ps1 b/build/test.ps1
index 423a6ad488..be6b89ba65 100644
--- a/build/test.ps1
+++ b/build/test.ps1
@@ -79,6 +79,29 @@ function Test-Python {
}
}
+function Test-JavaScript {
+ Param([string] $packageFolder, [string] $options)
+
+ Write-Host "##[info]Installing JS packages from $packageFolder"
+ Push-Location (Join-Path $PSScriptRoot $packageFolder)
+ npm install
+ Pop-Location
+
+ Write-Host "##[info]Testing JS inside $packageFolder"
+ Push-Location (Join-Path $PSScriptRoot $packageFolder)
+ if (!$options) {
+ npm test
+ } else {
+ npm test -- $options
+ }
+ Pop-Location
+
+ if ($LastExitCode -ne 0) {
+ Write-Host "##vso[task.logissue type=error;]Failed to test JS inside $packageFolder"
+ $script:all_ok = $False
+ }
+}
+
Test-One '../iqsharp.sln' @("AzureClient", "IQSharpEngine", "Workspace")
if ($Env:ENABLE_PYTHON -eq "false") {
@@ -87,6 +110,8 @@ if ($Env:ENABLE_PYTHON -eq "false") {
Test-Python '../src/Python/qsharp-core' '../src/Python/qsharp-core/qsharp/tests'
}
+Test-JavaScript '../src/Kernel'
+
if (-not $all_ok)
{
throw "At least one project failed to compile. Check the logs."
diff --git a/images/iqsharp-base/Dockerfile b/images/iqsharp-base/Dockerfile
index 66a05a5f3e..738b1f292a 100644
--- a/images/iqsharp-base/Dockerfile
+++ b/images/iqsharp-base/Dockerfile
@@ -109,7 +109,7 @@ ENV PATH=$PATH:${HOME}/dotnet:${HOME}/.dotnet/tools \
# Install IQ# and the project templates, using the NuGet packages from the
# build context.
ARG IQSHARP_VERSION
-RUN dotnet new -i "Microsoft.Quantum.ProjectTemplates::0.12.20072031" && \
+RUN dotnet new -i "Microsoft.Quantum.ProjectTemplates::0.12.20073008-beta" && \
dotnet tool install \
--global \
Microsoft.Quantum.IQSharp \
diff --git a/iqsharp.sln b/iqsharp.sln
index b7abcb6152..38a7e6ff59 100644
--- a/iqsharp.sln
+++ b/iqsharp.sln
@@ -17,7 +17,9 @@ Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "AzureClient", "src\AzureCli
EndProject
Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Jupyter", "src\Jupyter\Jupyter.csproj", "{19A9E2AB-8842-47E2-8E6A-6DD292B49E97}"
EndProject
-Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Mock.Chemistry", "src\Mock.Chemistry\Mock.Chemistry.csproj", "{2243DB2D-EFAC-4594-A44B-A25B399CE4DE}"
+Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Mock.Chemistry", "src\MockLibraries\Mock.Chemistry\Mock.Chemistry.csproj", "{AAAEA32B-3CFA-40D4-A7A0-D332ACB40BA1}"
+EndProject
+Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "Mock.Standard", "src\MockLibraries\Mock.Standard\Mock.Standard.csproj", "{854E40D3-64A2-4864-AB79-AB9CC61DA1DE}"
EndProject
Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution
@@ -113,18 +115,30 @@ Global
{19A9E2AB-8842-47E2-8E6A-6DD292B49E97}.Release|x64.Build.0 = Release|Any CPU
{19A9E2AB-8842-47E2-8E6A-6DD292B49E97}.Release|x86.ActiveCfg = Release|Any CPU
{19A9E2AB-8842-47E2-8E6A-6DD292B49E97}.Release|x86.Build.0 = Release|Any CPU
- {2243DB2D-EFAC-4594-A44B-A25B399CE4DE}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
- {2243DB2D-EFAC-4594-A44B-A25B399CE4DE}.Debug|Any CPU.Build.0 = Debug|Any CPU
- {2243DB2D-EFAC-4594-A44B-A25B399CE4DE}.Debug|x64.ActiveCfg = Debug|Any CPU
- {2243DB2D-EFAC-4594-A44B-A25B399CE4DE}.Debug|x64.Build.0 = Debug|Any CPU
- {2243DB2D-EFAC-4594-A44B-A25B399CE4DE}.Debug|x86.ActiveCfg = Debug|Any CPU
- {2243DB2D-EFAC-4594-A44B-A25B399CE4DE}.Debug|x86.Build.0 = Debug|Any CPU
- {2243DB2D-EFAC-4594-A44B-A25B399CE4DE}.Release|Any CPU.ActiveCfg = Release|Any CPU
- {2243DB2D-EFAC-4594-A44B-A25B399CE4DE}.Release|Any CPU.Build.0 = Release|Any CPU
- {2243DB2D-EFAC-4594-A44B-A25B399CE4DE}.Release|x64.ActiveCfg = Release|Any CPU
- {2243DB2D-EFAC-4594-A44B-A25B399CE4DE}.Release|x64.Build.0 = Release|Any CPU
- {2243DB2D-EFAC-4594-A44B-A25B399CE4DE}.Release|x86.ActiveCfg = Release|Any CPU
- {2243DB2D-EFAC-4594-A44B-A25B399CE4DE}.Release|x86.Build.0 = Release|Any CPU
+ {AAAEA32B-3CFA-40D4-A7A0-D332ACB40BA1}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
+ {AAAEA32B-3CFA-40D4-A7A0-D332ACB40BA1}.Debug|Any CPU.Build.0 = Debug|Any CPU
+ {AAAEA32B-3CFA-40D4-A7A0-D332ACB40BA1}.Debug|x64.ActiveCfg = Debug|Any CPU
+ {AAAEA32B-3CFA-40D4-A7A0-D332ACB40BA1}.Debug|x64.Build.0 = Debug|Any CPU
+ {AAAEA32B-3CFA-40D4-A7A0-D332ACB40BA1}.Debug|x86.ActiveCfg = Debug|Any CPU
+ {AAAEA32B-3CFA-40D4-A7A0-D332ACB40BA1}.Debug|x86.Build.0 = Debug|Any CPU
+ {AAAEA32B-3CFA-40D4-A7A0-D332ACB40BA1}.Release|Any CPU.ActiveCfg = Release|Any CPU
+ {AAAEA32B-3CFA-40D4-A7A0-D332ACB40BA1}.Release|Any CPU.Build.0 = Release|Any CPU
+ {AAAEA32B-3CFA-40D4-A7A0-D332ACB40BA1}.Release|x64.ActiveCfg = Release|Any CPU
+ {AAAEA32B-3CFA-40D4-A7A0-D332ACB40BA1}.Release|x64.Build.0 = Release|Any CPU
+ {AAAEA32B-3CFA-40D4-A7A0-D332ACB40BA1}.Release|x86.ActiveCfg = Release|Any CPU
+ {AAAEA32B-3CFA-40D4-A7A0-D332ACB40BA1}.Release|x86.Build.0 = Release|Any CPU
+ {854E40D3-64A2-4864-AB79-AB9CC61DA1DE}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
+ {854E40D3-64A2-4864-AB79-AB9CC61DA1DE}.Debug|Any CPU.Build.0 = Debug|Any CPU
+ {854E40D3-64A2-4864-AB79-AB9CC61DA1DE}.Debug|x64.ActiveCfg = Debug|Any CPU
+ {854E40D3-64A2-4864-AB79-AB9CC61DA1DE}.Debug|x64.Build.0 = Debug|Any CPU
+ {854E40D3-64A2-4864-AB79-AB9CC61DA1DE}.Debug|x86.ActiveCfg = Debug|Any CPU
+ {854E40D3-64A2-4864-AB79-AB9CC61DA1DE}.Debug|x86.Build.0 = Debug|Any CPU
+ {854E40D3-64A2-4864-AB79-AB9CC61DA1DE}.Release|Any CPU.ActiveCfg = Release|Any CPU
+ {854E40D3-64A2-4864-AB79-AB9CC61DA1DE}.Release|Any CPU.Build.0 = Release|Any CPU
+ {854E40D3-64A2-4864-AB79-AB9CC61DA1DE}.Release|x64.ActiveCfg = Release|Any CPU
+ {854E40D3-64A2-4864-AB79-AB9CC61DA1DE}.Release|x64.Build.0 = Release|Any CPU
+ {854E40D3-64A2-4864-AB79-AB9CC61DA1DE}.Release|x86.ActiveCfg = Release|Any CPU
+ {854E40D3-64A2-4864-AB79-AB9CC61DA1DE}.Release|x86.Build.0 = Release|Any CPU
EndGlobalSection
GlobalSection(SolutionProperties) = preSolution
HideSolutionNode = FALSE
diff --git a/src/AzureClient/AzureClient.csproj b/src/AzureClient/AzureClient.csproj
index b7d1ddbc08..fc021e4a9a 100644
--- a/src/AzureClient/AzureClient.csproj
+++ b/src/AzureClient/AzureClient.csproj
@@ -13,7 +13,7 @@
-
+
diff --git a/src/Core/Core.csproj b/src/Core/Core.csproj
index 6999bca672..f7a29284d3 100644
--- a/src/Core/Core.csproj
+++ b/src/Core/Core.csproj
@@ -38,9 +38,9 @@
-
-
-
+
+
+
diff --git a/src/Core/ExecutionPathTracer/ExecutionPath.cs b/src/Core/ExecutionPathTracer/ExecutionPath.cs
new file mode 100644
index 0000000000..95ca7e83e5
--- /dev/null
+++ b/src/Core/ExecutionPathTracer/ExecutionPath.cs
@@ -0,0 +1,156 @@
+// Copyright (c) Microsoft Corporation.
+// Licensed under the MIT License.
+
+#nullable enable
+
+using System.Collections.Generic;
+using Newtonsoft.Json;
+using Newtonsoft.Json.Serialization;
+
+namespace Microsoft.Quantum.IQSharp.Core.ExecutionPathTracer
+{
+ ///
+ /// Represents the qubit resources and operations traced out in an execution path of a Q# operation.
+ ///
+ public class ExecutionPath
+ {
+ ///
+ /// Initializes a new instance of the class.
+ ///
+ ///
+ /// A list of that represents the declared qubits used in the execution path.
+ ///
+ ///
+ /// A list of that represents the operations used in the execution path.
+ ///
+ public ExecutionPath(IEnumerable qubits, IEnumerable operations)
+ {
+ this.Qubits = qubits;
+ this.Operations = operations;
+ }
+
+ ///
+ /// A list of that represents the declared qubits used in the execution path.
+ ///
+ [JsonProperty("qubits")]
+ public IEnumerable Qubits { get; }
+
+ ///
+ /// A list of that represents the operations used in the execution path.
+ ///
+ [JsonProperty("operations")]
+ public IEnumerable Operations { get; }
+
+ ///
+ /// Serializes into its JSON representation.
+ ///
+ ///
+ /// Pretty prints the JSON (i.e. with white space and indents) if true.
+ ///
+ public string ToJson(bool prettyPrint = false) =>
+ JsonConvert.SerializeObject(this,
+ (prettyPrint) ? Formatting.Indented : Formatting.None,
+ new JsonSerializerSettings
+ {
+ NullValueHandling = NullValueHandling.Ignore,
+ }
+ );
+ }
+
+ ///
+ /// Represents a qubit resource used in an execution path.
+ ///
+ public class QubitDeclaration
+ {
+ ///
+ /// Initializes a new instance of the class.
+ ///
+ ///
+ /// Id of qubit.
+ ///
+ ///
+ /// Number of associated classical registers.
+ ///
+ public QubitDeclaration(int id, int numChildren = 0)
+ {
+ this.Id = id;
+ this.NumChildren = numChildren;
+ }
+
+ ///
+ /// Id of qubit.
+ ///
+ [JsonProperty("id")]
+ public int Id { get; }
+
+ ///
+ /// Number of associated classical registers.
+ ///
+ [JsonProperty("numChildren")]
+ public int NumChildren { get; }
+
+ ///
+ /// Used by to determine if
+ /// should be included in the JSON serialization.
+ ///
+ public bool ShouldSerializeNumChildren() => NumChildren > 0;
+ }
+
+ ///
+ /// Represents an operation used in an execution path.
+ ///
+ public class Operation
+ {
+ ///
+ /// Label of gate.
+ ///
+ [JsonProperty("gate")]
+ public string Gate { get; set; } = "";
+
+ ///
+ /// Arguments (except types) provided to gate that
+ /// will be displayed by the visualizer.
+ ///
+ [JsonProperty("displayArgs")]
+ public string? DisplayArgs { get; set; }
+
+ ///
+ /// Group of operations for each classical branch.
+ ///
+ ///
+ /// Currently not used as this is intended for classically-controlled operations.
+ ///
+ [JsonProperty("children")]
+ public IEnumerable>? Children { get; set; }
+
+ ///
+ /// True if operation is a measurement operations.
+ ///
+ [JsonProperty("isMeasurement")]
+ public bool IsMeasurement { get; set; }
+
+ ///
+ /// True if operation is a controlled operations.
+ ///
+ [JsonProperty("isControlled")]
+ public bool IsControlled { get; set; }
+
+ ///
+ /// True if operation is an adjoint operations.
+ ///
+ [JsonProperty("isAdjoint")]
+ public bool IsAdjoint { get; set; }
+
+ ///
+ /// List of control registers.
+ ///
+ [JsonProperty("controls")]
+ public IEnumerable Controls { get; set; } = new List();
+
+ ///
+ /// List of target registers.
+ ///
+ [JsonProperty("targets")]
+ public IEnumerable Targets { get; set; } = new List();
+ }
+}
diff --git a/src/Core/ExecutionPathTracer/ExecutionPathTracer.cs b/src/Core/ExecutionPathTracer/ExecutionPathTracer.cs
new file mode 100644
index 0000000000..830155fe1a
--- /dev/null
+++ b/src/Core/ExecutionPathTracer/ExecutionPathTracer.cs
@@ -0,0 +1,223 @@
+// Copyright (c) Microsoft Corporation.
+// Licensed under the MIT License.
+
+using System;
+using System.Collections.Generic;
+using System.Linq;
+using Microsoft.Quantum.Simulation.Core;
+
+#nullable enable
+
+namespace Microsoft.Quantum.IQSharp.Core.ExecutionPathTracer
+{
+ ///
+ /// Traces through the operations in a given execution path of a Q# program by hooking on
+ /// to a simulator via the event listeners and
+ /// , and generates the corresponding .
+ ///
+ public class ExecutionPathTracer
+ {
+ private int currentDepth = 0;
+ private int renderDepth;
+ private ICallable? currCompositeOp = null;
+ private ExecutionPathTracer? compositeTracer = null;
+ private Operation? currentOperation = null;
+ private IDictionary qubitRegisters = new Dictionary();
+ private IDictionary> classicalRegisters = new Dictionary>();
+ private List operations = new List();
+
+ ///
+ /// Initializes a new instance of the class with the depth to render operations at.
+ ///
+ ///
+ /// The depth at which to render operations.
+ ///
+ public ExecutionPathTracer(int depth = 1) => this.renderDepth = depth + 1;
+
+ ///
+ /// Returns the generated .
+ ///
+ public ExecutionPath GetExecutionPath() =>
+ new ExecutionPath(
+ this.qubitRegisters.Keys
+ .OrderBy(k => k)
+ .Select(k => new QubitDeclaration(k, (this.classicalRegisters.ContainsKey(k))
+ ? this.classicalRegisters[k].Count
+ : 0
+ )),
+ this.operations
+ );
+
+ ///
+ /// Provides the event listener to listen to
+ /// 's
+ /// OnOperationStart event.
+ ///
+ public void OnOperationStartHandler(ICallable operation, IApplyData arguments)
+ {
+ this.currentDepth++;
+
+ // If `compositeTracer` is initialized, pass operations into it instead
+ if (this.compositeTracer != null)
+ {
+ this.compositeTracer.OnOperationStartHandler(operation, arguments);
+ return;
+ }
+
+ // Only parse operations at or above (i.e. <= `renderDepth`) specified depth
+ if (this.currentDepth > this.renderDepth) return;
+
+ var metadata = operation.GetRuntimeMetadata(arguments);
+
+ // If metadata is a composite operation (i.e. want to trace its components instead),
+ // we recursively create a tracer that traces its components instead
+ if (metadata != null && metadata.IsComposite)
+ {
+ this.compositeTracer = new ExecutionPathTracer(0);
+ // Attach our registers by reference to compositeTracer
+ this.compositeTracer.qubitRegisters = this.qubitRegisters;
+ this.compositeTracer.classicalRegisters = this.classicalRegisters;
+ this.currCompositeOp = operation;
+ // Set currentOperation to null so we don't render higher-depth operations unintentionally.
+ this.currentOperation = null;
+ return;
+ }
+
+ // Save parsed operation as a potential candidate for rendering.
+ // We only want to render the operation at the lowest depth, so we keep
+ // a running track of the lowest operation seen in the stack thus far.
+ this.currentOperation = this.MetadataToOperation(metadata);
+ }
+
+ ///
+ /// Provides the event listener to listen to
+ /// 's
+ /// OnOperationEnd event.
+ ///
+ public void OnOperationEndHandler(ICallable operation, IApplyData result)
+ {
+ this.currentDepth--;
+
+ // If `compositeTracer` is not null, handle the incoming operation recursively.
+ if (this.compositeTracer != null)
+ {
+ // If the current operation is the composite operation we started with, append
+ // the operations traced out by the `compositeTracer` to the current list of
+ // operations and reset.
+ if (operation == this.currCompositeOp)
+ {
+ this.AddCompositeOperations();
+ this.currCompositeOp = null;
+ this.compositeTracer = null;
+ return;
+ }
+
+ // Pass operations down to it for handling
+ this.compositeTracer.OnOperationEndHandler(operation, result);
+ return;
+ }
+
+ // Add latest parsed operation to list of operations, if not null
+ if (this.currentOperation != null)
+ {
+ this.operations.Add(this.currentOperation);
+ this.currentOperation = null;
+ }
+ }
+
+ ///
+ /// Retrieves the associated with the given or create a new
+ /// one if it doesn't exist.
+ ///
+ private QubitRegister GetQubitRegister(Qubit qubit) =>
+ this.qubitRegisters.GetOrCreate(qubit.Id, new QubitRegister(qubit.Id));
+
+ private List GetQubitRegisters(IEnumerable qubits) =>
+ qubits.Select(this.GetQubitRegister).ToList();
+
+ ///
+ /// Creates a new and associate it with the given .
+ ///
+ private ClassicalRegister CreateClassicalRegister(Qubit measureQubit)
+ {
+ var qId = measureQubit.Id;
+ var cId = this.classicalRegisters.GetOrCreate(qId).Count;
+
+ var register = new ClassicalRegister(qId, cId);
+
+ // Add classical register under the given qubit id
+ this.classicalRegisters[qId].Add(register);
+
+ return register;
+ }
+
+ ///
+ /// Retrieves the most recent associated with the given .
+ ///
+ ///
+ /// Currently not used as this is intended for classically-controlled operations.
+ ///
+ private ClassicalRegister GetClassicalRegister(Qubit controlQubit)
+ {
+ var qId = controlQubit.Id;
+ if (!this.classicalRegisters.ContainsKey(qId) || this.classicalRegisters[qId].Count == 0)
+ {
+ throw new Exception("No classical registers found for qubit {qId}.");
+ }
+
+ // Get most recent measurement on given control qubit
+ var cId = this.classicalRegisters[qId].Count - 1;
+ return this.classicalRegisters[qId][cId];
+ }
+
+ ///
+ /// Parse s traced out by the compositeTracer.
+ ///
+ private void AddCompositeOperations()
+ {
+ if (this.compositeTracer == null)
+ throw new NullReferenceException("ERROR: compositeTracer not initialized.");
+
+ // The composite tracer has done its job and we retrieve the operations it traced
+ this.operations.AddRange(this.compositeTracer.operations);
+ }
+
+ ///
+ /// Parse into its corresponding .
+ ///
+ private Operation? MetadataToOperation(RuntimeMetadata? metadata)
+ {
+ if (metadata == null) return null;
+
+ var displayArgs = (metadata.FormattedNonQubitArgs.Length > 0)
+ ? metadata.FormattedNonQubitArgs
+ : null;
+
+ // Add surrounding parentheses around displayArgs if it doesn't already have it (i.e. not a tuple)
+ if (displayArgs != null && !displayArgs.StartsWith("(")) displayArgs = $"({displayArgs})";
+
+ var op = new Operation()
+ {
+ Gate = metadata.Label,
+ DisplayArgs = displayArgs,
+ Children = metadata.Children?.Select(child => child.Select(this.MetadataToOperation).WhereNotNull()),
+ IsControlled = metadata.IsControlled,
+ IsAdjoint = metadata.IsAdjoint,
+ Controls = this.GetQubitRegisters(metadata.Controls),
+ Targets = this.GetQubitRegisters(metadata.Targets),
+ };
+
+ // Create classical registers for measurement operations
+ if (metadata.IsMeasurement)
+ {
+ var measureQubit = metadata.Targets.ElementAt(0);
+ var clsReg = this.CreateClassicalRegister(measureQubit);
+ op.IsMeasurement = true;
+ op.Controls = op.Targets;
+ op.Targets = new List() { clsReg };
+ }
+
+ return op;
+ }
+ }
+}
diff --git a/src/Core/ExecutionPathTracer/Extensions.cs b/src/Core/ExecutionPathTracer/Extensions.cs
new file mode 100644
index 0000000000..f836620843
--- /dev/null
+++ b/src/Core/ExecutionPathTracer/Extensions.cs
@@ -0,0 +1,53 @@
+// Copyright (c) Microsoft Corporation.
+// Licensed under the MIT License.
+
+#nullable enable
+
+using System;
+using System.Collections.Generic;
+using System.Linq;
+using Microsoft.Quantum.Simulation.Common;
+using Microsoft.Quantum.Simulation.Core;
+
+namespace Microsoft.Quantum.IQSharp.Core.ExecutionPathTracer
+{
+ ///
+ /// Extension methods to be used with and by .
+ ///
+ public static class Extensions
+ {
+ ///
+ /// Attaches event listeners to the simulator to generate
+ /// the of the operation performed by the simulator.
+ ///
+ public static T WithExecutionPathTracer(this T sim, ExecutionPathTracer tracer)
+ where T : SimulatorBase
+ {
+ sim.OnOperationStart += tracer.OnOperationStartHandler;
+ sim.OnOperationEnd += tracer.OnOperationEndHandler;
+ return sim;
+ }
+
+ ///
+ /// Gets the value associated with the specified key and creates a new entry with the defaultVal if
+ /// the key doesn't exist.
+ ///
+ public static TValue GetOrCreate(this IDictionary dict, TKey key, TValue defaultVal)
+ {
+ TValue val;
+ if (!dict.TryGetValue(key, out val))
+ {
+ val = defaultVal;
+ dict.Add(key, val);
+ }
+ return val;
+ }
+
+ ///
+ /// Gets the value associated with the specified key and creates a new entry of the default type if
+ /// the key doesn't exist.
+ ///
+ public static TValue GetOrCreate(this IDictionary dict, TKey key)
+ where TValue : new() => dict.GetOrCreate(key, new TValue());
+ }
+}
diff --git a/src/Core/ExecutionPathTracer/Register.cs b/src/Core/ExecutionPathTracer/Register.cs
new file mode 100644
index 0000000000..a3560b73a3
--- /dev/null
+++ b/src/Core/ExecutionPathTracer/Register.cs
@@ -0,0 +1,90 @@
+// Copyright (c) Microsoft Corporation.
+// Licensed under the MIT License.
+
+#nullable enable
+
+using Newtonsoft.Json;
+using Newtonsoft.Json.Serialization;
+
+namespace Microsoft.Quantum.IQSharp.Core.ExecutionPathTracer
+{
+ ///
+ /// Enum for the 2 types of registers: Qubit and Classical.
+ ///
+ public enum RegisterType
+ {
+ ///
+ /// Qubit register that holds a qubit.
+ ///
+ Qubit,
+ ///
+ /// Classical register that holds a classical bit.
+ ///
+ Classical,
+ }
+
+ ///
+ /// Represents a register used by an .
+ ///
+ public class Register
+ {
+ ///
+ /// Type of register.
+ ///
+ [JsonProperty("type")]
+ public virtual RegisterType Type { get; }
+
+ ///
+ /// Qubit id of register.
+ ///
+ [JsonProperty("qId")]
+ public virtual int QId { get; protected set; }
+
+ ///
+ /// Classical bit id of register. null if register is a qubit register.
+ ///
+ [JsonProperty("cId")]
+ public virtual int? CId { get; protected set; }
+ }
+
+ ///
+ /// Represents a qubit register used by an .
+ ///
+ public class QubitRegister : Register
+ {
+ ///
+ /// Creates a new with the given qubit id.
+ ///
+ ///
+ /// Id of qubit register.
+ ///
+ public QubitRegister(int qId) => this.QId = qId;
+
+ ///
+ public override RegisterType Type => RegisterType.Qubit;
+ }
+
+ ///
+ /// Represents a classical register used by an .
+ ///
+ public class ClassicalRegister : Register
+ {
+ ///
+ /// Creates a new with the given qubit id and classical bit id.
+ ///
+ ///
+ /// Id of qubit register.
+ ///
+ ///
+ /// Id of classical register associated with the given qubit id.
+ ///
+ public ClassicalRegister(int qId, int cId)
+ {
+ this.QId = qId;
+ this.CId = cId;
+ }
+
+ ///
+ public override RegisterType Type => RegisterType.Classical;
+ }
+}
diff --git a/src/Jupyter/ConfigurationSource.cs b/src/Jupyter/ConfigurationSource.cs
index ba0d2b7630..08ac7366c0 100644
--- a/src/Jupyter/ConfigurationSource.cs
+++ b/src/Jupyter/ConfigurationSource.cs
@@ -89,6 +89,13 @@ public T GetOptionOrDefault(string optionName, T defaultValue) =>
///
public PhaseDisplayStyle PhaseDisplayStyle =>
GetOptionOrDefault("dump.phaseDisplayStyle", PhaseDisplayStyle.ArrowOnly);
+
+ ///
+ /// Allows for setting the default depth for visualizing Q# operations using the
+ /// %trace command.
+ ///
+ public int TraceVisualizationDefaultDepth =>
+ GetOptionOrDefault("trace.defaultDepth", 1);
}
///
diff --git a/src/Jupyter/Visualization/DisplayableHtmlElementEncoder.cs b/src/Jupyter/Visualization/DisplayableHtmlElementEncoder.cs
new file mode 100644
index 0000000000..91a7034ad3
--- /dev/null
+++ b/src/Jupyter/Visualization/DisplayableHtmlElementEncoder.cs
@@ -0,0 +1,42 @@
+// Copyright (c) Microsoft Corporation. All rights reserved.
+// Licensed under the MIT License.
+#nullable enable
+
+using Microsoft.Jupyter.Core;
+
+namespace Microsoft.Quantum.IQSharp.Jupyter
+{
+ ///
+ /// Represents an HTML string to be rendered as an HTML element.
+ ///
+ public class DisplayableHtmlElement
+ {
+ ///
+ /// Initializes with the given HTML string.
+ ///
+ public DisplayableHtmlElement(string html) => this.Html = html;
+
+ ///
+ /// HTML string to be rendered.
+ ///
+ public string Html { get; }
+ }
+
+ ///
+ /// Encodes instances as HTML elements.
+ ///
+ public class DisplayableHtmlElementEncoder : IResultEncoder
+ {
+ ///
+ public string MimeType => MimeTypes.Html;
+
+ ///
+ /// Checks if a given display object is an ,
+ /// and if so, returns its HTML element.
+ ///
+ public EncodedData? Encode(object displayable) =>
+ (displayable is DisplayableHtmlElement dis)
+ ? dis.Html.ToEncodedData() as EncodedData?
+ : null;
+ }
+}
diff --git a/src/Kernel/Extensions.cs b/src/Kernel/Extensions.cs
index 057ccecde8..1fd81e18e6 100644
--- a/src/Kernel/Extensions.cs
+++ b/src/Kernel/Extensions.cs
@@ -1,7 +1,6 @@
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
-using System;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Jupyter.Core;
using Microsoft.Quantum.IQSharp.Jupyter;
diff --git a/src/Kernel/IQSharpEngine.cs b/src/Kernel/IQSharpEngine.cs
index 1efb1afead..2a211f2dea 100644
--- a/src/Kernel/IQSharpEngine.cs
+++ b/src/Kernel/IQSharpEngine.cs
@@ -63,6 +63,7 @@ IReferences references
RegisterDisplayEncoder(new DataTableToTextEncoder());
RegisterDisplayEncoder(new DisplayableExceptionToHtmlEncoder());
RegisterDisplayEncoder(new DisplayableExceptionToTextEncoder());
+ RegisterDisplayEncoder(new DisplayableHtmlElementEncoder());
RegisterJsonEncoder(
JsonConverters.AllConverters
diff --git a/src/Kernel/Magic/ConfigMagic.cs b/src/Kernel/Magic/ConfigMagic.cs
index db8abdf039..dd715af8ab 100644
--- a/src/Kernel/Magic/ConfigMagic.cs
+++ b/src/Kernel/Magic/ConfigMagic.cs
@@ -6,9 +6,7 @@
using System.Linq;
using Microsoft.Jupyter.Core;
-using Microsoft.Quantum.IQSharp;
using Microsoft.Quantum.IQSharp.Jupyter;
-using Microsoft.Quantum.IQSharp.Kernel;
using Newtonsoft.Json;
using Newtonsoft.Json.Linq;
@@ -66,6 +64,12 @@ of basis states of a state vector.
Configures the phase visualization style in output from callables such as
`DumpMachine` or `DumpRegister`. Supports displaying phase as arrows, numbers (in radians), both, or neither.
+
+ **`trace.defaultDepth`**
+
+ **Value:** positive integer (default `1`)
+
+ Configures the default depth used in the `%trace` command for visualizing Q# operations.
".Dedent(),
Examples = new []
{
diff --git a/src/Kernel/Magic/TraceMagic.cs b/src/Kernel/Magic/TraceMagic.cs
new file mode 100644
index 0000000000..bbef6a8020
--- /dev/null
+++ b/src/Kernel/Magic/TraceMagic.cs
@@ -0,0 +1,183 @@
+// Copyright (c) Microsoft Corporation. All rights reserved.
+// Licensed under the MIT License.
+
+using System;
+using System.Threading.Tasks;
+using Microsoft.Jupyter.Core;
+using Microsoft.Jupyter.Core.Protocol;
+using Microsoft.Quantum.IQSharp.Core.ExecutionPathTracer;
+using Microsoft.Quantum.IQSharp.Jupyter;
+using Microsoft.Quantum.Simulation.Simulators;
+using Newtonsoft.Json;
+using Newtonsoft.Json.Linq;
+
+namespace Microsoft.Quantum.IQSharp.Kernel
+{
+ ///
+ /// Contains the JSON representation of the
+ /// and the ID of the HTML div that will contain the visualization of the
+ /// execution path.
+ ///
+ public class ExecutionPathVisualizerContent : MessageContent
+ {
+ ///
+ /// Initializes with the
+ /// given (as a ) and HTML div ID.
+ ///
+ public ExecutionPathVisualizerContent(JToken executionPath, string id)
+ {
+ this.ExecutionPath = executionPath;
+ this.Id = id;
+ }
+
+ ///
+ /// The (as a ) to be rendered.
+ ///
+ [JsonProperty("executionPath")]
+ public JToken ExecutionPath { get; }
+
+ ///
+ /// ID of the HTML div that will contain the visualization.
+ ///
+ [JsonProperty("id")]
+ public string Id { get; }
+ }
+
+ ///
+ /// A magic command that can be used to visualize the execution
+ /// path of operations and functions traced out by the simulator.
+ ///
+ public class TraceMagic : AbstractMagic
+ {
+ private const string ParameterNameOperationName = "__operationName__";
+ private const string ParameterNameDepth = "--depth";
+
+ ///
+ /// Constructs a new magic command given a resolver used to find
+ /// operations and functions, and a configuration source used to set
+ /// configuration options.
+ ///
+ public TraceMagic(ISymbolResolver resolver, IConfigurationSource configurationSource) : base(
+ "trace",
+ new Documentation
+ {
+ Summary = "Visualizes the execution path of the given operation.",
+ Description = $@"
+ This magic command renders an HTML-based visualization of a runtime execution path of the
+ given operation using the QuantumSimulator.
+
+ #### Required parameters
+
+ - Q# operation or function name. This must be the first parameter, and must be a valid Q# operation
+ or function name that has been defined either in the notebook or in a Q# file in the same folder.
+ - Arguments for the Q# operation or function must also be specified as `key=value` pairs.
+
+ #### Optional parameters
+
+ - `{ParameterNameDepth}=` (default=1): The depth at which to render operations along
+ the execution path.
+ ".Dedent(),
+ Examples = new[]
+ {
+ @"
+ Visualize the execution path of a Q# operation defined as `operation MyOperation() : Result`:
+ ```
+ In []: %trace MyOperation
+ Out[]:
+ ```
+ ".Dedent(),
+ @"
+ Visualize the execution path of a Q# operation defined as `operation MyOperation(a : Int, b : Int) : Result`:
+ ```
+ In []: %trace MyOperation a=5 b=10
+ Out[]:
+ ```
+ ".Dedent(),
+ $@"
+ Visualize operations at depth 2 on the execution path of a Q# operation defined
+ as `operation MyOperation() : Result`:
+ ```
+ In []: %trace MyOperation {ParameterNameDepth}=2
+ Out[]:
+ ```
+ ".Dedent(),
+ }
+ })
+ {
+ this.SymbolResolver = resolver;
+ this.ConfigurationSource = configurationSource;
+ }
+
+ ///
+ /// The symbol resolver used by this magic command to find the operation
+ /// to be visualized.
+ ///
+ public ISymbolResolver SymbolResolver { get; }
+
+ ///
+ /// The configuration source used by this magic command to control
+ /// visualization options.
+ ///
+ public IConfigurationSource ConfigurationSource { get; }
+
+ ///
+ public override ExecutionResult Run(string input, IChannel channel) =>
+ RunAsync(input, channel).Result;
+
+ ///
+ /// Outputs a visualization of a runtime execution path of an operation given
+ /// a string with its name and a JSON encoding of its arguments.
+ ///
+ public async Task RunAsync(string input, IChannel channel)
+ {
+ // Parse input parameters
+ var inputParameters = ParseInputParameters(input, firstParameterInferredName: ParameterNameOperationName);
+
+ var name = inputParameters.DecodeParameter(ParameterNameOperationName);
+ var symbol = SymbolResolver.Resolve(name) as IQSharpSymbol;
+ if (symbol == null) throw new InvalidOperationException($"Invalid operation name: {name}");
+
+ var depth = inputParameters.DecodeParameter(
+ ParameterNameDepth,
+ defaultValue: this.ConfigurationSource.TraceVisualizationDefaultDepth
+ );
+ if (depth <= 0) throw new ArgumentOutOfRangeException($"Invalid depth: {depth}. Must be >= 1.");
+
+ var tracer = new ExecutionPathTracer(depth);
+
+ // Simulate operation and attach `ExecutionPathTracer` to trace out operations performed
+ // in its execution path
+ using var qsim = new QuantumSimulator()
+ .WithJupyterDisplay(channel, ConfigurationSource)
+ .WithStackTraceDisplay(channel)
+ .WithExecutionPathTracer(tracer);
+ var value = await symbol.Operation.RunAsync(qsim, inputParameters);
+
+ // Retrieve the `ExecutionPath` traced out by the `ExecutionPathTracer`
+ var executionPath = tracer.GetExecutionPath();
+
+ // Convert executionPath to JToken for serialization
+ var executionPathJToken = JToken.FromObject(executionPath,
+ new JsonSerializer() { NullValueHandling = NullValueHandling.Ignore });
+
+ // Render empty div with unique ID as cell output
+ var divId = $"execution-path-container-{Guid.NewGuid().ToString()}";
+ var content = new ExecutionPathVisualizerContent(executionPathJToken, divId);
+ channel.DisplayUpdatable(new DisplayableHtmlElement($""));
+
+ // Send execution path to JavaScript via iopub for rendering
+ channel.SendIoPubMessage(
+ new Message
+ {
+ Header = new MessageHeader
+ {
+ MessageType = "render_execution_path"
+ },
+ Content = content,
+ }
+ );
+
+ return ExecuteStatus.Ok.ToExecutionResult();
+ }
+ }
+}
diff --git a/src/Kernel/client/ExecutionPathVisualizer/constants.ts b/src/Kernel/client/ExecutionPathVisualizer/constants.ts
new file mode 100644
index 0000000000..aea7c9deb6
--- /dev/null
+++ b/src/Kernel/client/ExecutionPathVisualizer/constants.ts
@@ -0,0 +1,51 @@
+/**
+ * Enum for the various gate operations handled.
+ */
+export enum GateType {
+ /** Measurement gate. */
+ Measure,
+ /** CNOT gate. */
+ Cnot,
+ /** SWAP gate. */
+ Swap,
+ /** Single/multi qubit unitary gate. */
+ Unitary,
+ /** Single/multi controlled unitary gate. */
+ ControlledUnitary,
+ /** Nested group of classically-controlled gates. */
+ ClassicalControlled,
+ /** Invalid gate. */
+ Invalid
+};
+
+// Display attributes
+/** Left padding of SVG. */
+export const leftPadding: number = 20;
+/** x coordinate for first operation on each register. */
+export const startX: number = 80;
+/** y coordinate of first register. */
+export const startY: number = 40;
+/** Minimum width of each gate. */
+export const minGateWidth: number = 40;
+/** Height of each gate. */
+export const gateHeight: number = 40;
+/** Padding on each side of gate. */
+export const gatePadding: number = 10;
+/** Padding on each side of gate label. */
+export const labelPadding: number = 10;
+/** Height between each qubit register. */
+export const registerHeight: number = gateHeight + gatePadding * 2;
+/** Height between classical registers. */
+export const classicalRegHeight: number = gateHeight;
+/** Classical box inner padding. */
+export const classicalBoxPadding: number = 15;
+/** Additional offset for control button. */
+export const controlBtnOffset: number = 40;
+/** Control button radius. */
+export const controlBtnRadius: number = 15;
+/** Default font size for gate labels. */
+export const labelFontSize: number = 14;
+/** Default font size for gate arguments. */
+export const argsFontSize: number = 12;
+/** Starting x coord for each register wire. */
+export const regLineStart: number = 40;
diff --git a/src/Kernel/client/ExecutionPathVisualizer/executionPath.ts b/src/Kernel/client/ExecutionPathVisualizer/executionPath.ts
new file mode 100644
index 0000000000..3b8cbfed46
--- /dev/null
+++ b/src/Kernel/client/ExecutionPathVisualizer/executionPath.ts
@@ -0,0 +1,45 @@
+import { Register } from "./register";
+
+/**
+ * Structure of JSON representation of the execution path of a Q# operation.
+ */
+export interface ExecutionPath {
+ /** Array of qubit resources. */
+ qubits: Qubit[];
+ operations: Operation[];
+};
+
+/**
+ * Represents a unique qubit resource bit.
+ */
+export interface Qubit {
+ /** Qubit ID. */
+ id: number;
+ /** Number of classical registers attached to quantum register. */
+ numChildren?: number;
+};
+
+/**
+ * Represents an operation and the registers it acts on.
+ */
+export interface Operation {
+ /** Gate label. */
+ gate: string;
+ /** Formatted gate arguments to be displayed. */
+ displayArgs?: string,
+ /** Classically-controlled gates.
+ * - children[0]: gates when classical control bit is 0.
+ * - children[1]: gates when classical control bit is 1.
+ */
+ children?: Operation[][];
+ /** Whether gate is a measurement operation. */
+ isMeasurement: boolean;
+ /** Whether gate is a controlled operation. */
+ isControlled: boolean;
+ /** Whether gate is an adjoint operation. */
+ isAdjoint: boolean;
+ /** Control registers the gate acts on. */
+ controls: Register[];
+ /** Target registers the gate acts on. */
+ targets: Register[];
+};
diff --git a/src/Kernel/client/ExecutionPathVisualizer/formatters/formatUtils.ts b/src/Kernel/client/ExecutionPathVisualizer/formatters/formatUtils.ts
new file mode 100644
index 0000000000..7e9556fffe
--- /dev/null
+++ b/src/Kernel/client/ExecutionPathVisualizer/formatters/formatUtils.ts
@@ -0,0 +1,104 @@
+import { labelFontSize } from "../constants";
+
+// Helper functions for basic SVG components
+
+/**
+ * Given an array of SVG elements, group them as an SVG group using the `` tag.
+ *
+ * @param svgElems Array of SVG elements.
+ *
+ * @returns SVG string for grouped elements.
+ */
+export const group = (...svgElems: (string | string[])[]): string =>
+ ['', ...svgElems.flat(), ''].join('\n');
+
+/**
+ * Generate the SVG representation of a control dot used for controlled operations.
+ *
+ * @param x x coord of circle.
+ * @param y y coord of circle.
+ * @param radius Radius of circle.
+ *
+ * @returns SVG string for control dot.
+ */
+export const controlDot = (x: number, y: number, radius: number = 5): string =>
+ ``;
+
+/**
+ * Generate an SVG line.
+ *
+ * @param x1 x coord of starting point of line.
+ * @param y1 y coord of starting point of line.
+ * @param x2 x coord of ending point of line.
+ * @param y2 y coord fo ending point of line.
+ * @param strokeWidth Stroke width of line.
+ *
+ * @returns SVG string for line.
+ */
+export const line = (x1: number, y1: number, x2: number, y2: number, strokeWidth: number = 1): string =>
+ ``;
+
+/**
+ * Generate the SVG representation of a unitary box that represents an arbitrary unitary operation.
+ *
+ * @param x x coord of box.
+ * @param y y coord of box.
+ * @param width Width of box.
+ * @param height Height of box.
+ *
+ * @returns SVG string for unitary box.
+ */
+export const box = (x: number, y: number, width: number, height: number): string =>
+ ``;
+
+/**
+ * Generate the SVG text element from a given text string.
+ *
+ * @param text String to render as SVG text.
+ * @param x Middle x coord of text.
+ * @param y Middle y coord of text.
+ * @param fs Font size of text.
+ *
+ * @returns SVG string for text.
+ */
+export const text = (text: string, x: number, y: number, fs: number = labelFontSize): string =>
+ `${text}`;
+
+/**
+ * Generate the SVG representation of the arc used in the measurement box.
+ *
+ * @param x x coord of arc.
+ * @param y y coord of arc.
+ * @param rx x radius of arc.
+ * @param ry y radius of arc.
+ *
+ * @returns SVG string for arc.
+ */
+export const arc = (x: number, y: number, rx: number, ry: number): string =>
+ ``;
+
+/**
+ * Generate a dashed SVG line.
+ *
+ * @param x1 x coord of starting point of line.
+ * @param y1 y coord of starting point of line.
+ * @param x2 x coord of ending point of line.
+ * @param y2 y coord fo ending point of line.
+ *
+ * @returns SVG string for dashed line.
+ */
+export const dashedLine = (x1: number, y1: number, x2: number, y2: number): string =>
+ ``;
+
+/**
+ * Generate the SVG representation of the dashed box used for enclosing groups of operations controlled on a classical register.
+ *
+ * @param x x coord of box.
+ * @param y y coord of box.
+ * @param width Width of box.
+ * @param height Height of box.
+ *
+ * @returns SVG string for dashed box.
+ */
+export const dashedBox = (x: number, y: number, width: number, height: number): string =>
+ ``;
diff --git a/src/Kernel/client/ExecutionPathVisualizer/formatters/gateFormatter.ts b/src/Kernel/client/ExecutionPathVisualizer/formatters/gateFormatter.ts
new file mode 100644
index 0000000000..ca2b22a3d8
--- /dev/null
+++ b/src/Kernel/client/ExecutionPathVisualizer/formatters/gateFormatter.ts
@@ -0,0 +1,309 @@
+import { Metadata } from "../metadata";
+import {
+ GateType,
+ minGateWidth,
+ gateHeight,
+ registerHeight,
+ labelFontSize,
+ argsFontSize,
+ controlBtnRadius,
+ controlBtnOffset,
+ classicalBoxPadding,
+ classicalRegHeight,
+} from "../constants";
+import {
+ group,
+ controlDot,
+ line,
+ box,
+ text,
+ arc,
+ dashedLine,
+ dashedBox
+} from "./formatUtils";
+
+/**
+ * Given an array of operations (in metadata format), return the SVG representation.
+ *
+ * @param opsMetadata Array of Metadata representation of operations.
+ *
+ * @returns SVG representation of operations.
+ */
+const formatGates = (opsMetadata: Metadata[]): string => {
+ const formattedGates: string[] = opsMetadata.map(_formatGate);
+ return formattedGates.flat().join('\n');
+};
+
+/**
+ * Takes in an operation's metadata and formats it into SVG.
+ *
+ * @param metadata Metadata object representation of gate.
+ *
+ * @returns SVG representation of gate.
+ */
+const _formatGate = (metadata: Metadata): string => {
+ const { type, x, controlsY, targetsY, label, displayArgs, width } = metadata;
+ switch (type) {
+ case GateType.Measure:
+ return _measure(x, controlsY[0], targetsY[0]);
+ case GateType.Unitary:
+ return _unitary(label, x, targetsY, width, displayArgs);
+ case GateType.Swap:
+ if (controlsY.length > 0) return _controlledGate(metadata);
+ else return _swap(x, targetsY);
+ case GateType.Cnot:
+ case GateType.ControlledUnitary:
+ return _controlledGate(metadata);
+ case GateType.ClassicalControlled:
+ return _classicalControlled(metadata);
+ default:
+ throw new Error(`ERROR: unknown gate (${label}) of type ${type}.`);
+ }
+};
+
+/**
+ * Creates a measurement gate at the x position, where qy and cy are
+ * the y coords of the qubit register and classical register, respectively.
+ *
+ * @param x x coord of measurement gate.
+ * @param qy y coord of qubit register.
+ * @param cy y coord of classical register.
+ *
+ * @returns SVG representation of measurement gate.
+ */
+const _measure = (x: number, qy: number, cy: number): string => {
+ x -= minGateWidth / 2;
+ const width: number = minGateWidth, height = gateHeight;
+ // Draw measurement box
+ const mBox: string = box(x, qy - height / 2, width, height);
+ const mArc: string = arc(x + 5, qy + 2, width / 2 - 5, height / 2 - 8);
+ const meter: string = line(x + width / 2, qy + 8, x + width - 8, qy - height / 2 + 8);
+ const svg: string = group(mBox, mArc, meter);
+ return svg;
+};
+
+/**
+ * Creates the SVG for a unitary gate on an arbitrary number of qubits.
+ *
+ * @param label Gate label.
+ * @param x x coord of gate.
+ * @param y Array of y coords of registers acted upon by gate.
+ * @param width Width of gate.
+ * @param displayArgs Arguments passed in to gate.
+ * @param renderDashedLine If true, draw dashed lines between non-adjacent unitaries.
+ *
+ * @returns SVG representation of unitary gate.
+ */
+const _unitary = (label: string, x: number, y: number[], width: number, displayArgs?: string, renderDashedLine: boolean = true): string => {
+ if (y.length === 0) return "";
+
+ // Sort y in ascending order
+ y.sort((y1, y2) => y1 - y2);
+
+ // Group adjacent registers
+ let prevY: number = y[0];
+ const regGroups: number[][] = y.reduce((groups: number[][], currY: number) => {
+ // Registers are defined to be adjacent if they differ by registerHeight in their y coord
+ // NOTE: This method of group registers by height difference might break if we want to add
+ // registers with variable heights.
+ if (groups.length === 0 || currY - prevY > registerHeight) groups.push([currY]);
+ else groups[groups.length - 1].push(currY);
+ prevY = currY;
+ return groups;
+ }, []);
+
+ // Render each group as a separate unitary boxes
+ const unitaryBoxes: string[] = regGroups.map((group: number[]) => {
+ const maxY: number = group[group.length - 1], minY: number = group[0];
+ const height: number = maxY - minY + gateHeight;
+ return _unitaryBox(label, x, minY, width, height, displayArgs);
+ });
+
+ // Draw dashed line between disconnected unitaries
+ if (renderDashedLine && unitaryBoxes.length > 1) {
+ const maxY: number = y[y.length - 1], minY: number = y[0];
+ const vertLine: string = dashedLine(x, minY, x, maxY);
+ return [vertLine, ...unitaryBoxes].join('\n');
+ } else return unitaryBoxes.join('\n');
+};
+
+/**
+ * Generates SVG representation of the boxed unitary gate symbol.
+ *
+ * @param label Label for unitary operation.
+ * @param x x coord of gate.
+ * @param y y coord of gate.
+ * @param width Width of gate.
+ * @param height Height of gate.
+ * @param displayArgs Arguments passed in to gate.
+ *
+ * @returns SVG representation of unitary box.
+ */
+const _unitaryBox = (label: string, x: number, y: number, width: number, height: number = gateHeight, displayArgs?: string): string => {
+ y -= gateHeight / 2;
+ const uBox: string = box(x - width / 2, y, width, height);
+ const labelY = y + height / 2 - ((displayArgs == null) ? 0 : 7);
+ const labelText: string = text(label, x, labelY);
+ const elems = [uBox, labelText];
+ if (displayArgs != null) {
+ const argStrY = y + height / 2 + 8;
+ const argText: string = text(displayArgs, x, argStrY, argsFontSize);
+ elems.push(argText);
+ }
+ const svg: string = group(elems);
+ return svg;
+};
+
+/**
+ * Creates the SVG for a SWAP gate on y coords given by targetsY.
+ *
+ * @param x Centre x coord of SWAP gate.
+ * @param targetsY y coords of target registers.
+ *
+ * @returns SVG representation of SWAP gate.
+ */
+const _swap = (x: number, targetsY: number[]): string => {
+ // Get SVGs of crosses
+ const crosses: string[] = targetsY.map(y => _cross(x, y));
+ const vertLine: string = line(x, targetsY[0], x, targetsY[1]);
+ const svg: string = group(crosses, vertLine);
+ return svg;
+};
+
+/**
+ * Generates cross for display in SWAP gate.
+ *
+ * @param x x coord of gate.
+ * @param y y coord of gate.
+ *
+ * @returns SVG representation for cross.
+ */
+const _cross = (x: number, y: number): string => {
+ const radius: number = 8;
+ const line1: string = line(x - radius, y - radius, x + radius, y + radius);
+ const line2: string = line(x - radius, y + radius, x + radius, y - radius);
+ return [line1, line2].join('\n');
+};
+
+/**
+ * Produces the SVG representation of a controlled gate on multiple qubits.
+ *
+ * @param metadata Metadata of controlled gate.
+ *
+ * @returns SVG representation of controlled gate.
+ */
+const _controlledGate = (metadata: Metadata): string => {
+ const targetGateSvgs: string[] = [];
+ const { type, x, controlsY, targetsY, label, displayArgs, width } = metadata;
+ // Get SVG for target gates
+ switch (type) {
+ case GateType.Cnot:
+ targetsY.forEach(y => targetGateSvgs.push(_oplus(x, y)));
+ break;
+ case GateType.Swap:
+ targetsY.forEach(y => targetGateSvgs.push(_cross(x, y)));
+ break;
+ case GateType.ControlledUnitary:
+ targetGateSvgs.push(_unitary(label, x, targetsY, width, displayArgs, false));
+ break;
+ default:
+ throw new Error(`ERROR: Unrecognized gate: ${label} of type ${type}`);
+ }
+ // Get SVGs for control dots
+ const controlledDotsSvg: string[] = controlsY.map(y => controlDot(x, y));
+ // Create control lines
+ const maxY: number = Math.max(...controlsY, ...targetsY);
+ const minY: number = Math.min(...controlsY, ...targetsY);
+ const vertLine: string = line(x, minY, x, maxY);
+ const svg: string = group(vertLine, controlledDotsSvg, targetGateSvgs);
+ return svg;
+};
+
+/**
+ * Generates $\oplus$ symbol for display in CNOT gate.
+ *
+ * @param x x coordinate of gate.
+ * @param y y coordinate of gate.
+ * @param r radius of circle.
+ *
+ * @returns SVG representation of $\oplus$ symbol.
+ */
+const _oplus = (x: number, y: number, r: number = 15): string => {
+ const circle: string = ``;
+ const vertLine: string = line(x, y - r, x, y + r);
+ const horLine: string = line(x - r, y, x + r, y);
+ const svg: string = group(circle, vertLine, horLine);
+ return svg;
+}
+
+/**
+ * Generates the SVG for a classically controlled group of oeprations.
+ *
+ * @param metadata Metadata representation of gate.
+ * @param padding Padding within dashed box.
+ *
+ * @returns SVG representation of gate.
+ */
+const _classicalControlled = (metadata: Metadata, padding: number = classicalBoxPadding): string => {
+ let { x, controlsY, targetsY, width, children, htmlClass } = metadata;
+
+ const controlY = controlsY[0];
+ if (htmlClass == null) htmlClass = 'cls-control';
+
+ // Get SVG for gates controlled on 0 and make them hidden initially
+ let childrenZero: string = (children != null) ? formatGates(children[0]) : '';
+ childrenZero = `\r\n${childrenZero}`;
+
+ // Get SVG for gates controlled on 1
+ let childrenOne: string = (children != null) ? formatGates(children[1]) : '';
+ childrenOne = `\r\n${childrenOne}`;
+
+ // Draw control button and attached dashed line to dashed box
+ const controlCircleX: number = x + controlBtnRadius;
+ const controlCircle: string = _controlCircle(controlCircleX, controlY, htmlClass);
+ const lineY1: number = controlY + controlBtnRadius, lineY2: number = controlY + classicalRegHeight / 2;
+ const vertLine: string = dashedLine(controlCircleX, lineY1, controlCircleX, lineY2);
+ x += controlBtnOffset;
+ const horLine: string = dashedLine(controlCircleX, lineY2, x, lineY2);
+
+ width = width - controlBtnOffset + (padding - classicalBoxPadding) * 2;
+ x += classicalBoxPadding - padding;
+ const y: number = targetsY[0] - gateHeight / 2 - padding;
+ const height: number = targetsY[1] - targetsY[0] + gateHeight + padding * 2;
+
+ // Draw dashed box around children gates
+ const box: string = dashedBox(x, y, width, height);
+
+ // Display controlled operation in initial "unknown" state
+ const svg: string = group(``, horLine, vertLine,
+ controlCircle, childrenZero, childrenOne, box, '');
+
+ return svg;
+};
+
+/**
+ * Generates the SVG representation of the control circle on a classical register with interactivity support
+ * for toggling between bit values (unknown, 1, and 0).
+ *
+ * @param x x coord.
+ * @param y y coord.
+ * @param cls Class name.
+ * @param r Radius of circle.
+ *
+ * @returns SVG representation of control circle.
+ */
+const _controlCircle = (x: number, y: number, cls: string, r: number = controlBtnRadius): string =>
+ `
+
+?
+`;
+
+export {
+ formatGates,
+ _formatGate,
+ _measure,
+ _unitary,
+ _swap,
+ _controlledGate,
+ _classicalControlled,
+};
\ No newline at end of file
diff --git a/src/Kernel/client/ExecutionPathVisualizer/formatters/inputFormatter.ts b/src/Kernel/client/ExecutionPathVisualizer/formatters/inputFormatter.ts
new file mode 100644
index 0000000000..9a24ed6698
--- /dev/null
+++ b/src/Kernel/client/ExecutionPathVisualizer/formatters/inputFormatter.ts
@@ -0,0 +1,68 @@
+import { Qubit } from "../executionPath";
+import { RegisterType, RegisterMap, RegisterMetadata } from "../register";
+import {
+ leftPadding,
+ startY,
+ registerHeight,
+ classicalRegHeight,
+} from "../constants";
+
+/**
+ * `formatInputs` takes in an array of Qubits and outputs the SVG string of formatted
+ * qubit wires and a mapping from register IDs to register metadata (for rendering).
+ *
+ * @param qubits List of declared qubits.
+ *
+ * @returns returns the SVG string of formatted qubit wires, a mapping from registers
+ * to y coord and total SVG height.
+ */
+const formatInputs = (qubits: Qubit[]): { qubitWires: string, registers: RegisterMap, svgHeight: number } => {
+ const qubitWires: string[] = [];
+ const registers: RegisterMap = {};
+
+ let currY: number = startY;
+ qubits.forEach(({ id, numChildren }) => {
+ // Add qubit wire to list of qubit wires
+ qubitWires.push(_qubitInput(currY));
+
+ // Create qubit register
+ registers[id] = { type: RegisterType.Qubit, y: currY };
+
+ // If there are no attached classical registers, increment y by fixed register height
+ if (numChildren == null || numChildren === 0) {
+ currY += registerHeight;
+ return;
+ }
+
+ // Increment current height by classical register height for attached classical registers
+ currY += classicalRegHeight;
+
+ // Add classical wires
+ registers[id].children = Array.from(Array(numChildren), _ => {
+ const clsReg: RegisterMetadata = { type: RegisterType.Classical, y: currY };
+ currY += classicalRegHeight;
+ return clsReg;
+ });
+ });
+
+ return {
+ qubitWires: qubitWires.join('\n'),
+ registers,
+ svgHeight: currY
+ };
+};
+
+/**
+ * Generate the SVG text component for the input qubit register.
+ *
+ * @param y y coord of input wire to render in SVG.
+ *
+ * @returns SVG text component for the input register.
+ */
+const _qubitInput = (y: number): string =>
+ `|0⟩`;
+
+export {
+ formatInputs,
+ _qubitInput,
+};
diff --git a/src/Kernel/client/ExecutionPathVisualizer/formatters/registerFormatter.ts b/src/Kernel/client/ExecutionPathVisualizer/formatters/registerFormatter.ts
new file mode 100644
index 0000000000..3a8447005a
--- /dev/null
+++ b/src/Kernel/client/ExecutionPathVisualizer/formatters/registerFormatter.ts
@@ -0,0 +1,77 @@
+import { RegisterMap } from "../register";
+import { regLineStart, GateType } from "../constants";
+import { Metadata } from "../metadata";
+import { line } from "./formatUtils";
+
+/**
+ * Generate the SVG representation of the qubit register wires in `registers` and the classical wires
+ * stemming from each measurement gate.
+ *
+ * @param registers Map from register IDs to register metadata.
+ * @param measureGates Array of measurement gates metadata.
+ * @param endX End x coord.
+ *
+ * @returns SVG representation of register wires.
+ */
+const formatRegisters = (registers: RegisterMap, measureGates: Metadata[], endX: number): string => {
+ const formattedRegs: string[] = [];
+ // Render qubit wires
+ for (const qId in registers) {
+ formattedRegs.push(_qubitRegister(Number(qId), endX, registers[qId].y));
+ }
+ // Render classical wires
+ measureGates.forEach(({ type, x, targetsY, controlsY }) => {
+ if (type !== GateType.Measure) return;
+ const gateY: number = controlsY[0];
+ targetsY.forEach(y => {
+ formattedRegs.push(_classicalRegister(x, gateY, endX, y));
+ });
+ });
+ return formattedRegs.join('\n');
+};
+
+/**
+ * Generates the SVG representation of a classical register.
+ *
+ * @param startX Start x coord.
+ * @param gateY y coord of measurement gate.
+ * @param endX End x coord.
+ * @param wireY y coord of wire.
+ *
+ * @returns SVG representation of the given classical register.
+ */
+const _classicalRegister = (startX: number, gateY: number, endX: number, wireY: number): string => {
+ const wirePadding: number = 1;
+ // Draw vertical lines
+ const vLine1: string = line(startX + wirePadding, gateY, startX + wirePadding, wireY - wirePadding, 0.5);
+ const vLine2: string = line(startX - wirePadding, gateY, startX - wirePadding, wireY + wirePadding, 0.5);
+ // Draw horizontal lines
+ const hLine1: string = line(startX + wirePadding, wireY - wirePadding, endX, wireY - wirePadding, 0.5);
+ const hLine2: string = line(startX - wirePadding, wireY + wirePadding, endX, wireY + wirePadding, 0.5);
+ const svg: string = [vLine1, vLine2, hLine1, hLine2].join('\n');
+ return svg;
+};
+
+/**
+ * Generates the SVG representation of a qubit register.
+ *
+ * @param qId Qubit register index.
+ * @param endX End x coord.
+ * @param y y coord of wire.
+ * @param labelOffset y offset for wire label.
+ *
+ * @returns SVG representation of the given qubit register.
+ */
+const _qubitRegister = (qId: number, endX: number, y: number, labelOffset: number = 16): string => {
+ const labelY: number = y - labelOffset;
+ const wire: string = line(regLineStart, y, endX, y);
+ const label: string = `q${qId}`;
+ const svg: string = [wire, label].join('\n');
+ return svg;
+};
+
+export {
+ formatRegisters,
+ _classicalRegister,
+ _qubitRegister,
+};
diff --git a/src/Kernel/client/ExecutionPathVisualizer/metadata.ts b/src/Kernel/client/ExecutionPathVisualizer/metadata.ts
new file mode 100644
index 0000000000..2fe9bd7619
--- /dev/null
+++ b/src/Kernel/client/ExecutionPathVisualizer/metadata.ts
@@ -0,0 +1,29 @@
+import { GateType } from "./constants";
+
+/**
+ * Metadata used to store information pertaining to a given
+ * operation for rendering its corresponding SVG.
+ */
+export interface Metadata {
+ /** Gate type. */
+ type: GateType;
+ /** Centre x coord for gate position. */
+ x: number;
+ /** Array of y coords of control registers. */
+ controlsY: number[];
+ /** Array of y coords of target registers. */
+ targetsY: number[];
+ /** Gate label. */
+ label: string;
+ /** Gate arguments as string. */
+ displayArgs?: string,
+ /** Gate width. */
+ width: number;
+ /** Classically-controlled gates.
+ * - children[0]: gates when classical control bit is 0.
+ * - children[1]: gates when classical control bit is 1.
+ */
+ children?: Metadata[][];
+ /** HTML element class for interactivity. */
+ htmlClass?: string;
+};
diff --git a/src/Kernel/client/ExecutionPathVisualizer/pathVisualizer.ts b/src/Kernel/client/ExecutionPathVisualizer/pathVisualizer.ts
new file mode 100644
index 0000000000..6e8315a461
--- /dev/null
+++ b/src/Kernel/client/ExecutionPathVisualizer/pathVisualizer.ts
@@ -0,0 +1,135 @@
+import { formatInputs } from "./formatters/inputFormatter";
+import { formatGates } from "./formatters/gateFormatter";
+import { formatRegisters } from "./formatters/registerFormatter";
+import { processOperations } from "./process";
+import { ExecutionPath } from "./executionPath";
+import { Metadata } from "./metadata";
+import { GateType } from "./constants";
+
+const script = `
+
+`;
+
+const style = `
+
+`;
+
+/**
+ * Converts JSON representing an execution path of a Q# program given by the simulator and returns its HTML visualization.
+ *
+ * @param json JSON received from simulator.
+ *
+ * @returns HTML representation of circuit.
+ */
+const _jsonToHtml = (json: ExecutionPath): string => {
+ const { qubits, operations } = json;
+ const { qubitWires, registers, svgHeight } = formatInputs(qubits);
+ const { metadataList, svgWidth } = processOperations(operations, registers);
+ const formattedGates: string = formatGates(metadataList);
+ const measureGates: Metadata[] = metadataList.filter(({ type }) => type === GateType.Measure);
+ const formattedRegs: string = formatRegisters(registers, measureGates, svgWidth);
+ return `
+
+`;
+};
+
+/**
+ * Renders the given `ExecutionPath` json into an HTML element and populates the div
+ * with the given `id` with it.
+ *
+ * @param json JSON received from simulator.
+ * @param id ID of div to populate.
+ */
+const renderExecutionPath = (json: ExecutionPath, id: string): void => {
+ const html: string = _jsonToHtml(json);
+ const container: HTMLElement = document.getElementById(id);
+ if (container == null) throw new Error(`Div with ID ${id} not found.`);
+ container.innerHTML = html;
+};
+
+export default renderExecutionPath;
diff --git a/src/Kernel/client/ExecutionPathVisualizer/process.ts b/src/Kernel/client/ExecutionPathVisualizer/process.ts
new file mode 100644
index 0000000000..5d81e9f854
--- /dev/null
+++ b/src/Kernel/client/ExecutionPathVisualizer/process.ts
@@ -0,0 +1,357 @@
+import {
+ minGateWidth,
+ startX,
+ gatePadding,
+ GateType,
+ controlBtnOffset,
+ classicalBoxPadding,
+} from "./constants";
+import { Operation } from "./executionPath";
+import { Metadata } from "./metadata";
+import { Register, RegisterMap, RegisterType } from "./register";
+import { getGateWidth } from "./utils";
+
+/**
+ * Takes in a list of operations and maps them to `metadata` objects which
+ * contains information for formatting the corresponding SVG.
+ *
+ * @param operations Array of operations.
+ * @param registers Array of registers.
+ *
+ * @returns An object containing `metadataList` (Array of Metadata objects) and
+ * `svgWidth` which is the width of the entire SVG.
+ */
+const processOperations = (operations: Operation[], registers: RegisterMap)
+ : { metadataList: Metadata[], svgWidth: number } => {
+
+ // Group operations based on registers
+ const groupedOps: number[][] = _groupOperations(operations, registers);
+
+ // Align operations on multiple registers
+ const alignedOps: (number | null)[][] = _alignOps(groupedOps);
+
+ // Maintain widths of each column to account for variable-sized gates
+ const numColumns: number = Math.max(...alignedOps.map(ops => ops.length));
+ const columnsWidths: number[] = new Array(numColumns).fill(minGateWidth);
+ // Keep track of which ops are already seen to avoid duplicate rendering
+ const visited: { [opIdx: number]: boolean } = {};
+ // Unique HTML class for each classically-controlled group of gates.
+ let cls: number = 1;
+
+ // Map operation index to gate metadata for formatting later
+ const opsMetadata: Metadata[][] = alignedOps.map((regOps) =>
+ regOps.map((opIdx, col) => {
+ let op: Operation | null = null;
+
+ if (opIdx != null && !visited.hasOwnProperty(opIdx)) {
+ op = operations[opIdx];
+ visited[opIdx] = true;
+ }
+
+ const metadata: Metadata = _opToMetadata(op, registers);
+
+ // Add HTML class attribute if classically controlled
+ if (metadata.type === GateType.ClassicalControlled) {
+ _addClass(metadata, `cls-control-${cls++}`);
+ }
+
+ // Expand column size, if needed
+ if (metadata.width > columnsWidths[col]) {
+ columnsWidths[col] = metadata.width;
+ }
+
+ return metadata;
+ })
+ );
+
+ // Fill in x coord of each gate
+ const endX: number = _fillMetadataX(opsMetadata, columnsWidths);
+
+ // Flatten operations and filter out invalid gates
+ const metadataList: Metadata[] = opsMetadata.flat().filter(({ type }) => type != GateType.Invalid);
+
+ return { metadataList, svgWidth: endX };
+};
+
+/**
+ * Group gates provided by operations into their respective registers.
+ *
+ * @param operations Array of operations.
+ * @param numRegs Total number of registers.
+ *
+ * @returns 2D array of indices where `groupedOps[i][j]` is the index of the operations
+ * at register `i` and column `j` (not yet aligned/padded).
+ */
+const _groupOperations = (operations: Operation[], registers: RegisterMap): number[][] => {
+ // NOTE: We get the max ID instead of just number of keys because there can be a qubit ID that
+ // isn't acted upon and thus does not show up as a key in registers.
+ const numRegs: number = Math.max(...Object.keys(registers).map(Number)) + 1;
+ const groupedOps: number[][] = Array.from(Array(numRegs), () => new Array(0));
+ operations.forEach(({ targets, controls }, instrIdx) => {
+ const qRegs: Register[] = [...controls, ...targets].filter(({ type }) => type === RegisterType.Qubit);
+ const qRegIdxList: number[] = qRegs.map(({ qId }) => qId);
+ const clsControls: Register[] = controls.filter(({ type }) => type === RegisterType.Classical);
+ const isClassicallyControlled: boolean = clsControls.length > 0;
+ // If operation is classically-controlled, pad all qubit registers. Otherwise, only pad
+ // the contiguous range of registers that it covers.
+ const minRegIdx: number = (isClassicallyControlled) ? 0 : Math.min(...qRegIdxList);
+ const maxRegIdx: number = (isClassicallyControlled) ? numRegs - 1 : Math.max(...qRegIdxList);
+ // Add operation also to registers that are in-between target registers
+ // so that other gates won't render in the middle.
+ for (let i = minRegIdx; i <= maxRegIdx; i++) {
+ groupedOps[i].push(instrIdx);
+ }
+ });
+ return groupedOps;
+};
+
+/**
+ * Aligns operations by padding registers with `null`s to make sure that multiqubit
+ * gates are in the same column.
+ * e.g. ---[x]---[x]--
+ * ----------|---
+ *
+ * @param ops 2D array of operations. Each row represents a register
+ * and the operations acting on it (in-order).
+ *
+ * @returns 2D array of aligned operations padded with `null`s.
+ */
+const _alignOps = (ops: number[][]): (number | null)[][] => {
+ let maxNumOps: number = Math.max(...ops.map(regOps => regOps.length));
+ let col: number = 0;
+ // Deep copy ops to be returned as paddedOps
+ const paddedOps: (number | null)[][] = JSON.parse(JSON.stringify(ops));
+ while (col < maxNumOps) {
+ for (let regIdx = 0; regIdx < paddedOps.length; regIdx++) {
+ const reg: (number | null)[] = paddedOps[regIdx];
+ if (reg.length <= col) continue;
+
+ // Should never be null (nulls are only padded to previous columns)
+ const opIdx: (number | null) = reg[col];
+
+ // Get position of gate
+ const targetsPos: number[] = paddedOps.map(regOps => regOps.indexOf(opIdx));
+ const gatePos: number = Math.max(...targetsPos);
+
+ // If current column is not desired gate position, pad with null
+ if (col < gatePos) {
+ paddedOps[regIdx].splice(col, 0, null);
+ maxNumOps = Math.max(maxNumOps, paddedOps[regIdx].length);
+ }
+ }
+ col++;
+ }
+ return paddedOps;
+}
+
+/**
+ * Given an array of column widths, calculate the middle x coord of each column.
+ * This will be used to centre the gates within each column.
+ *
+ * @param columnWidths Array of column widths where `columnWidths[i]` is the
+ * width of the `i`th column.
+ *
+ * @returns Object containing the middle x coords of each column (`columnsX`) and the width
+ * of the corresponding SVG (`svgWidth`).
+ */
+const _getColumnsX = (columnWidths: number[]): { columnsX: number[], svgWidth: number } => {
+ const columnsX: number[] = new Array(columnWidths.length).fill(0);
+ let x: number = startX;
+ columnWidths.forEach((width, i) => {
+ columnsX[i] = x + width / 2;
+ x += width + gatePadding * 2;
+ });
+ return { columnsX, svgWidth: x };
+};
+
+/**
+ * Maps operation to metadata (e.g. gate type, position, dimensions, text)
+ * required to render the image.
+ *
+ * @param op Operation to be mapped into metadata format.
+ * @param registers Array of registers.
+ *
+ * @returns Metadata representation of given operation.
+ */
+const _opToMetadata = (op: Operation | null, registers: RegisterMap): Metadata => {
+ const metadata: Metadata = {
+ type: GateType.Invalid,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ label: '',
+ width: minGateWidth,
+ };
+
+ if (op == null) return metadata;
+
+ let {
+ gate,
+ displayArgs,
+ isMeasurement,
+ isControlled,
+ isAdjoint,
+ controls,
+ targets,
+ children
+ } = op;
+
+ // Set y coords
+ metadata.controlsY = controls.map(reg => _getRegY(reg, registers));
+ metadata.targetsY = targets.map(reg => _getRegY(reg, registers));
+
+ if (children != null && children.length > 0) {
+ // Classically-controlled operations
+
+ // Gates to display when classical bit is 0.
+ let childrenInstrs = processOperations(children[0], registers);
+ const zeroGates: Metadata[] = childrenInstrs.metadataList;
+ const zeroChildWidth: number = childrenInstrs.svgWidth;
+
+ // Gates to display when classical bit is 1.
+ childrenInstrs = processOperations(children[1], registers);
+ const oneGates: Metadata[] = childrenInstrs.metadataList;
+ const oneChildWidth: number = childrenInstrs.svgWidth;
+
+ // Subtract startX (left-side) and 2*gatePadding (right-side) from nested child gates width
+ const width: number = Math.max(zeroChildWidth, oneChildWidth) - startX - gatePadding * 2;
+
+ metadata.type = GateType.ClassicalControlled;
+ metadata.children = [zeroGates, oneGates];
+ // Add additional width from control button and inner box padding for dashed box
+ metadata.width = width + controlBtnOffset + classicalBoxPadding * 2;
+
+ // Set targets to first and last quantum registers so we can render the surrounding box
+ // around all quantum registers.
+ const qubitsY: number[] = Object.values(registers).map(({ y }) => y);
+ metadata.targetsY = [Math.min(...qubitsY), Math.max(...qubitsY)];
+ } else if (isMeasurement) {
+ metadata.type = GateType.Measure;
+ } else if (gate === 'SWAP') {
+ metadata.type = GateType.Swap;
+ } else if (isControlled) {
+ metadata.type = (gate === 'X') ? GateType.Cnot : GateType.ControlledUnitary;
+ metadata.label = gate;
+ } else {
+ // Any other gate treated as a simple unitary gate
+ metadata.type = GateType.Unitary;
+ metadata.label = gate;
+ }
+
+ // If adjoint, add ' to the end of gate label
+ if (isAdjoint && metadata.label.length > 0) metadata.label += "'";
+
+ // If gate has extra arguments, display them
+ if (displayArgs != null) metadata.displayArgs = displayArgs;
+
+ // Set gate width
+ metadata.width = getGateWidth(metadata);
+
+ return metadata;
+};
+
+/**
+ * Compute the y coord of a given register.
+ *
+ * @param reg Register to compute y coord of.
+ * @param registers Map of qubit IDs to RegisterMetadata.
+ *
+ * @returns The y coord of give register.
+ */
+const _getRegY = (reg: Register, registers: RegisterMap): number => {
+ const { type, qId, cId } = reg;
+ if (!registers.hasOwnProperty(qId)) throw new Error(`ERROR: Qubit register with ID ${qId} not found.`);
+ const { y, children } = registers[qId];
+ switch (type) {
+ case RegisterType.Qubit:
+ return y;
+ case RegisterType.Classical:
+ if (children == null) throw new Error(`ERROR: No classical registers found for qubit ID ${qId}.`);
+ if (cId == null) throw new Error(`ERROR: No ID defined for classical register associated with qubit ID ${qId}.`);
+ if (children.length <= cId)
+ throw new Error(`ERROR: Classical register ID ${cId} invalid for qubit ID ${qId} with ${children.length} classical register(s).`);
+ return children[cId].y;
+ default:
+ throw new Error(`ERROR: Unknown register type ${type}.`);
+ }
+};
+
+/**
+ * Adds HTML class to metadata and its nested children.
+ *
+ * @param metadata Metadata assigned to class.
+ * @param cls HTML class name.
+ */
+const _addClass = (metadata: Metadata, cls: string): void => {
+ metadata.htmlClass = cls;
+ if (metadata.children != null) {
+ metadata.children[0].forEach(child => _addClass(child, cls));
+ metadata.children[1].forEach(child => _addClass(child, cls));
+ }
+};
+
+/**
+ * Updates the x coord of each metadata in the given 2D array of metadata and returns rightmost x coord.
+ *
+ * @param opsMetadata 2D array of metadata.
+ * @param columnWidths Array of column widths.
+ *
+ * @returns Rightmost x coord.
+ */
+const _fillMetadataX = (opsMetadata: Metadata[][], columnWidths: number[]): number => {
+ let currX: number = startX;
+
+ const colStartX: number[] = columnWidths.map(width => {
+ const x: number = currX;
+ currX += width + gatePadding * 2;
+ return x;
+ });
+
+ const endX: number = currX;
+
+ opsMetadata.forEach(regOps => regOps.forEach((metadata, col) => {
+ const x = colStartX[col];
+ if (metadata.type === GateType.ClassicalControlled) {
+ // Subtract startX offset from nested gates and add offset and padding
+ const offset: number = x - startX + controlBtnOffset + classicalBoxPadding;
+
+ // Offset each x coord in children gates
+ _offsetChildrenX(metadata.children, offset);
+
+ // We don't use the centre x coord because we only care about the rightmost x for
+ // rendering the box around the group of nested gates
+ metadata.x = x;
+ } else {
+ // Get x coord of middle of each column (used for centering gates in a column)
+ metadata.x = x + columnWidths[col] / 2;
+ }
+ }));
+
+ return endX;
+};
+
+/**
+ * Offset x coords of nested children operations.
+ *
+ * @param children 2D array of children metadata.
+ * @param offset x coord offset.
+ */
+const _offsetChildrenX = (children: (Metadata[][] | undefined), offset: number): void => {
+ if (children == null) return;
+ children.flat().forEach(child => {
+ child.x += offset;
+ _offsetChildrenX(child.children, offset);
+ });
+};
+
+export {
+ processOperations,
+ _groupOperations,
+ _alignOps,
+ _getColumnsX,
+ _opToMetadata,
+ _getRegY,
+ _addClass,
+ _fillMetadataX,
+ _offsetChildrenX,
+};
diff --git a/src/Kernel/client/ExecutionPathVisualizer/register.ts b/src/Kernel/client/ExecutionPathVisualizer/register.ts
new file mode 100644
index 0000000000..1a50b130a5
--- /dev/null
+++ b/src/Kernel/client/ExecutionPathVisualizer/register.ts
@@ -0,0 +1,32 @@
+/**
+ * Type of register.
+ */
+export enum RegisterType {
+ Qubit,
+ Classical
+};
+
+/**
+ * Represents a register resource.
+ */
+export interface Register {
+ /** Type of register. */
+ type: RegisterType;
+ /** Qubit register ID. */
+ qId: number;
+ /** Classical register ID (if classical register). */
+ cId?: number;
+};
+
+export interface RegisterMetadata {
+ /** Type of register. */
+ type: RegisterType;
+ /** y coord of register */
+ y: number;
+ /** Nested classical registers attached to quantum register. */
+ children?: RegisterMetadata[];
+};
+
+export interface RegisterMap {
+ [id: number]: RegisterMetadata
+};
diff --git a/src/Kernel/client/ExecutionPathVisualizer/utils.ts b/src/Kernel/client/ExecutionPathVisualizer/utils.ts
new file mode 100644
index 0000000000..2468d514d3
--- /dev/null
+++ b/src/Kernel/client/ExecutionPathVisualizer/utils.ts
@@ -0,0 +1,55 @@
+import { Metadata } from './metadata';
+import {
+ GateType,
+ minGateWidth,
+ labelPadding,
+ labelFontSize,
+ argsFontSize,
+} from './constants';
+
+/**
+ * Calculate the width of a gate, given its metadata.
+ *
+ * @param metadata Metadata of a given gate.
+ *
+ * @returns Width of given gate (in pixels).
+ */
+const getGateWidth = ({ type, label, displayArgs, width }: Metadata): number => {
+ switch (type) {
+ case GateType.ClassicalControlled:
+ // Already computed before.
+ return width;
+ case GateType.Measure:
+ case GateType.Cnot:
+ case GateType.Swap:
+ return minGateWidth;
+ default:
+ const labelWidth = _getStringWidth(label);
+ const argsWidth = (displayArgs != null) ? _getStringWidth(displayArgs, argsFontSize) : 0;
+ const textWidth = Math.max(labelWidth, argsWidth) + labelPadding * 2;
+ return Math.max(minGateWidth, textWidth);
+ }
+};
+
+/**
+ * Get the width of a string with font-size `fontSize` and font-family Arial.
+ *
+ * @param text Input string.
+ * @param fontSize Font size of `text`.
+ *
+ * @returns Pixel width of given string.
+ */
+const _getStringWidth = (text: string, fontSize: number = labelFontSize): number => {
+ var canvas: HTMLCanvasElement = document.createElement("canvas");
+ var context: CanvasRenderingContext2D | null = canvas.getContext("2d");
+ if (context == null) throw new Error("Null canvas");
+
+ context.font = `${fontSize}px Arial`;
+ var metrics: TextMetrics = context.measureText(text);
+ return metrics.width;
+};
+
+export {
+ getGateWidth,
+ _getStringWidth,
+};
diff --git a/src/Kernel/client/__tests__/ExecutionPathVisualizerTests/__snapshots__/gateFormatter.test.ts.snap b/src/Kernel/client/__tests__/ExecutionPathVisualizerTests/__snapshots__/gateFormatter.test.ts.snap
new file mode 100644
index 0000000000..c81bd2640f
--- /dev/null
+++ b/src/Kernel/client/__tests__/ExecutionPathVisualizerTests/__snapshots__/gateFormatter.test.ts.snap
@@ -0,0 +1,665 @@
+// Jest Snapshot v1, https://goo.gl/fbAQLP
+
+exports[`Testing _classicalControlled No htmlClass 1`] = `
+"
+
+
+
+
+
+?
+
+
+
+
+
+
+X
+
+
+
+"
+`;
+
+exports[`Testing _classicalControlled change padding 1`] = `
+"
+
+
+
+
+
+?
+
+
+
+
+
+
+X
+
+
+
+"
+`;
+
+exports[`Testing _classicalControlled multiple 'zero'/'one' children 1`] = `
+"
+
+
+
+
+
+?
+
+
+
+
+X
+
+
+
+
+X
+
+
+
+
+
+
+
+
+
+
+
+
+"
+`;
+
+exports[`Testing _classicalControlled nested children 1`] = `
+"
+
+
+
+
+
+?
+
+
+
+
+
+
+X
+
+
+
+
+
+
+
+?
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+"
+`;
+
+exports[`Testing _classicalControlled one 'one' child 1`] = `
+"
+
+
+
+
+
+?
+
+
+
+
+
+
+X
+
+
+
+"
+`;
+
+exports[`Testing _classicalControlled one 'zero' child 1`] = `
+"
+
+
+
+
+
+?
+
+
+
+
+X
+
+
+
+
+
+"
+`;
+
+exports[`Testing _controlledGate CNOT gate 1`] = `
+"
+
+
+
+
+
+
+
+"
+`;
+
+exports[`Testing _controlledGate CNOT gate 2`] = `
+"
+
+
+
+
+
+
+
+"
+`;
+
+exports[`Testing _controlledGate Controlled U gate with 1 control + 1 target 1`] = `
+"
+
+
+
+
+Foo
+
+"
+`;
+
+exports[`Testing _controlledGate Controlled U gate with 1 control + 1 target 2`] = `
+"
+
+
+
+
+Foo
+
+"
+`;
+
+exports[`Testing _controlledGate Controlled U gate with 1 control + 2 targets 1`] = `
+"
+
+
+
+
+Foo
+
+"
+`;
+
+exports[`Testing _controlledGate Controlled U gate with 1 control + 2 targets 2`] = `
+"
+
+
+
+
+Foo
+
+"
+`;
+
+exports[`Testing _controlledGate Controlled U gate with 1 control + 2 targets 3`] = `
+"
+
+
+
+
+Foo
+
+
+
+Foo
+
+"
+`;
+
+exports[`Testing _controlledGate Controlled U gate with 2 controls + 2 targets 1`] = `
+"
+
+
+
+
+
+Foo
+
+"
+`;
+
+exports[`Testing _controlledGate Controlled U gate with 2 controls + 2 targets 2`] = `
+"
+
+
+
+
+
+Foo
+
+"
+`;
+
+exports[`Testing _controlledGate Controlled U gate with 2 controls + 2 targets 3`] = `
+"
+
+
+
+
+
+Foo
+
+
+
+Foo
+
+"
+`;
+
+exports[`Testing _controlledGate Controlled U gate with 2 controls + 2 targets 4`] = `
+"
+
+
+
+
+
+Foo
+
+
+
+Foo
+
+"
+`;
+
+exports[`Testing _controlledGate Controlled U gate with multiple controls + 1 target 1`] = `
+"
+
+
+
+
+
+Foo
+
+"
+`;
+
+exports[`Testing _controlledGate Controlled U gate with multiple controls + 1 target 2`] = `
+"
+
+
+
+
+
+Foo
+
+"
+`;
+
+exports[`Testing _controlledGate Controlled U gate with multiple controls + 1 target 3`] = `
+"
+
+
+
+
+
+Foo
+
+"
+`;
+
+exports[`Testing _controlledGate SWAP gate 1`] = `
+"
+
+
+
+
+
+
+"
+`;
+
+exports[`Testing _controlledGate SWAP gate 2`] = `
+"
+
+
+
+
+
+
+"
+`;
+
+exports[`Testing _controlledGate SWAP gate 3`] = `
+"
+
+
+
+
+
+
+"
+`;
+
+exports[`Testing _formatGate CNOT gate 1`] = `
+"
+
+
+
+
+
+
+
+"
+`;
+
+exports[`Testing _formatGate classically controlled gate 1`] = `
+"
+
+
+
+
+
+?
+
+
+
+
+
+
+
+"
+`;
+
+exports[`Testing _formatGate controlled swap gate 1`] = `
+"
+
+
+
+
+
+
+"
+`;
+
+exports[`Testing _formatGate controlled unitary gate 1`] = `
+"
+
+
+
+
+U
+
+"
+`;
+
+exports[`Testing _formatGate controlled unitary gate with arguments 1`] = `
+"
+
+
+
+
+U
+('foo', 'bar')
+
+"
+`;
+
+exports[`Testing _formatGate measure gate 1`] = `
+"
+
+
+
+"
+`;
+
+exports[`Testing _formatGate multi-qubit unitary gate 1`] = `
+"
+
+U
+"
+`;
+
+exports[`Testing _formatGate multi-qubit unitary gate with arguments 1`] = `
+"
+
+
+
+U
+('foo', 'bar')
+
+"
+`;
+
+exports[`Testing _formatGate single-qubit unitary gate 1`] = `
+"
+
+H
+"
+`;
+
+exports[`Testing _formatGate single-qubit unitary gate with arguments 1`] = `
+"
+
+Ry
+(0.25)
+"
+`;
+
+exports[`Testing _formatGate swap gate 1`] = `
+"
+
+
+
+
+
+"
+`;
+
+exports[`Testing _measure 1 qubit + 1 classical registers 1`] = `
+"
+
+
+
+"
+`;
+
+exports[`Testing _measure 2 qubit + 1 classical registers 1`] = `
+"
+
+
+
+"
+`;
+
+exports[`Testing _measure 2 qubit + 2 classical registers 1`] = `
+"
+
+
+
+"
+`;
+
+exports[`Testing _measure 2 qubit + 2 classical registers 2`] = `
+"
+
+
+
+"
+`;
+
+exports[`Testing _swap Adjacent swap 1`] = `
+"
+
+
+
+
+
+"
+`;
+
+exports[`Testing _swap Adjacent swap 2`] = `
+"
+
+
+
+
+
+"
+`;
+
+exports[`Testing _swap Non-adjacent swap 1`] = `
+"
+
+
+
+
+
+"
+`;
+
+exports[`Testing _swap Non-adjacent swap 2`] = `
+"
+
+
+
+
+
+"
+`;
+
+exports[`Testing _unitary Multiqubit unitary on consecutive registers 1`] = `
+"
+
+ZZ
+"
+`;
+
+exports[`Testing _unitary Multiqubit unitary on consecutive registers 2`] = `
+"
+
+ZZZ
+"
+`;
+
+exports[`Testing _unitary Multiqubit unitary on non-consecutive registers 1`] = `
+"
+
+
+ZZ
+
+
+
+ZZ
+"
+`;
+
+exports[`Testing _unitary Multiqubit unitary on non-consecutive registers 2`] = `
+"
+
+
+ZZZ
+
+
+
+ZZZ
+"
+`;
+
+exports[`Testing _unitary Multiqubit unitary on non-consecutive registers 3`] = `
+"
+
+ZZ
+
+
+
+ZZ
+"
+`;
+
+exports[`Testing _unitary Multiqubit unitary on non-consecutive registers 4`] = `
+"
+
+ZZZ
+
+
+
+ZZZ
+"
+`;
+
+exports[`Testing _unitary Single qubit unitary 1`] = `
+"
+
+H
+"
+`;
+
+exports[`Testing formatGates Multiple gates 1`] = `
+"
+
+
+
+
+
+
+
+
+
+
+
+
+
+X
+
+
+
+
+X
+
+
+
+
+
+"
+`;
+
+exports[`Testing formatGates Single gate 1`] = `
+"
+
+
+
+
+
+
+
+"
+`;
diff --git a/src/Kernel/client/__tests__/ExecutionPathVisualizerTests/__snapshots__/inputFormatter.test.ts.snap b/src/Kernel/client/__tests__/ExecutionPathVisualizerTests/__snapshots__/inputFormatter.test.ts.snap
new file mode 100644
index 0000000000..59a157b807
--- /dev/null
+++ b/src/Kernel/client/__tests__/ExecutionPathVisualizerTests/__snapshots__/inputFormatter.test.ts.snap
@@ -0,0 +1,32 @@
+// Jest Snapshot v1, https://goo.gl/fbAQLP
+
+exports[`Testing _qubitInput classical register 1`] = `"|0⟩"`;
+
+exports[`Testing _qubitInput classical register 2`] = `"|0⟩"`;
+
+exports[`Testing _qubitInput classical register 3`] = `"|0⟩"`;
+
+exports[`Testing formatInputs 1 quantum register 1`] = `"|0⟩"`;
+
+exports[`Testing formatInputs Multiple quantum registers 1`] = `
+"|0⟩
+|0⟩
+|0⟩"
+`;
+
+exports[`Testing formatInputs Quantum and classical registers 1`] = `
+"|0⟩
+|0⟩
+|0⟩"
+`;
+
+exports[`Testing formatInputs Quantum and classical registers 2`] = `
+"|0⟩
+|0⟩
+|0⟩"
+`;
+
+exports[`Testing formatInputs Skip quantum registers 1`] = `
+"|0⟩
+|0⟩"
+`;
diff --git a/src/Kernel/client/__tests__/ExecutionPathVisualizerTests/__snapshots__/registerFormatter.test.ts.snap b/src/Kernel/client/__tests__/ExecutionPathVisualizerTests/__snapshots__/registerFormatter.test.ts.snap
new file mode 100644
index 0000000000..a7e0185637
--- /dev/null
+++ b/src/Kernel/client/__tests__/ExecutionPathVisualizerTests/__snapshots__/registerFormatter.test.ts.snap
@@ -0,0 +1,322 @@
+// Jest Snapshot v1, https://goo.gl/fbAQLP
+
+exports[`Testing _classicalRegister register with label offset 1`] = `
+"
+
+
+"
+`;
+
+exports[`Testing _classicalRegister register with label offset 2`] = `
+"
+
+
+"
+`;
+
+exports[`Testing _classicalRegister register with label offset 3`] = `
+"
+
+
+"
+`;
+
+exports[`Testing _classicalRegister register with large width 1`] = `
+"
+
+
+"
+`;
+
+exports[`Testing _classicalRegister register with large width 2`] = `
+"
+
+
+"
+`;
+
+exports[`Testing _classicalRegister register with large width 3`] = `
+"
+
+
+"
+`;
+
+exports[`Testing _classicalRegister register with normal width 1`] = `
+"
+
+
+"
+`;
+
+exports[`Testing _classicalRegister register with normal width 2`] = `
+"
+
+
+"
+`;
+
+exports[`Testing _classicalRegister register with normal width 3`] = `
+"
+
+
+"
+`;
+
+exports[`Testing _classicalRegister register with small width 1`] = `
+"
+
+
+"
+`;
+
+exports[`Testing _classicalRegister register with small width 2`] = `
+"
+
+
+"
+`;
+
+exports[`Testing _classicalRegister register with small width 3`] = `
+"
+
+
+"
+`;
+
+exports[`Testing _qubitRegister register with label offset 1`] = `
+"
+q0"
+`;
+
+exports[`Testing _qubitRegister register with label offset 2`] = `
+"
+q1"
+`;
+
+exports[`Testing _qubitRegister register with label offset 3`] = `
+"
+q2"
+`;
+
+exports[`Testing _qubitRegister register with large width 1`] = `
+"
+q0"
+`;
+
+exports[`Testing _qubitRegister register with large width 2`] = `
+"
+q1"
+`;
+
+exports[`Testing _qubitRegister register with large width 3`] = `
+"
+q2"
+`;
+
+exports[`Testing _qubitRegister register with normal width 1`] = `
+"
+q0"
+`;
+
+exports[`Testing _qubitRegister register with normal width 2`] = `
+"
+q1"
+`;
+
+exports[`Testing _qubitRegister register with normal width 3`] = `
+"
+q2"
+`;
+
+exports[`Testing _qubitRegister register with small width 1`] = `
+"
+q0"
+`;
+
+exports[`Testing _qubitRegister register with small width 2`] = `
+"
+q1"
+`;
+
+exports[`Testing _qubitRegister register with small width 3`] = `
+"
+q2"
+`;
+
+exports[`Testing formatRegisters 1 quantum register 1`] = `
+"
+q0"
+`;
+
+exports[`Testing formatRegisters 1 quantum register 2`] = `
+"
+q0"
+`;
+
+exports[`Testing formatRegisters 1 quantum register 3`] = `
+"
+q0"
+`;
+
+exports[`Testing formatRegisters Multiple quantum registers 1`] = `
+"
+q0
+
+q1
+
+q2
+
+q3"
+`;
+
+exports[`Testing formatRegisters Multiple quantum registers 2`] = `
+"
+q0
+
+q1
+
+q2
+
+q3"
+`;
+
+exports[`Testing formatRegisters Multiple quantum registers 3`] = `
+"
+q0
+
+q1
+
+q2
+
+q3"
+`;
+
+exports[`Testing formatRegisters Quantum and classical registers 1`] = `
+"
+q0
+
+q1
+
+q2
+
+
+
+"
+`;
+
+exports[`Testing formatRegisters Quantum and classical registers 2`] = `
+"
+q0
+
+q1
+
+q2
+
+
+
+"
+`;
+
+exports[`Testing formatRegisters Quantum and classical registers 3`] = `
+"
+q0
+
+q1
+
+q2
+
+
+
+"
+`;
+
+exports[`Testing formatRegisters Quantum and classical registers 4`] = `
+"
+q0
+
+q1
+
+q2
+
+
+
+
+
+
+
+
+
+
+
+"
+`;
+
+exports[`Testing formatRegisters Quantum and classical registers 5`] = `
+"
+q0
+
+q1
+
+q2
+
+
+
+
+
+
+
+
+
+
+
+"
+`;
+
+exports[`Testing formatRegisters Quantum and classical registers 6`] = `
+"
+q0
+
+q1
+
+q2
+
+
+
+
+
+
+
+
+
+
+
+"
+`;
+
+exports[`Testing formatRegisters Skipped quantum registers 1`] = `
+"
+q0
+
+q2
+
+q3"
+`;
+
+exports[`Testing formatRegisters Skipped quantum registers 2`] = `
+"
+q0
+
+q2
+
+q3"
+`;
+
+exports[`Testing formatRegisters Skipped quantum registers 3`] = `
+"
+q0
+
+q2
+
+q3"
+`;
diff --git a/src/Kernel/client/__tests__/ExecutionPathVisualizerTests/gateFormatter.test.ts b/src/Kernel/client/__tests__/ExecutionPathVisualizerTests/gateFormatter.test.ts
new file mode 100644
index 0000000000..014346aa4b
--- /dev/null
+++ b/src/Kernel/client/__tests__/ExecutionPathVisualizerTests/gateFormatter.test.ts
@@ -0,0 +1,664 @@
+import {
+ formatGates,
+ _formatGate,
+ _measure,
+ _unitary,
+ _swap,
+ _controlledGate,
+ _classicalControlled
+} from "../../ExecutionPathVisualizer/formatters/gateFormatter";
+import { Metadata } from "../../ExecutionPathVisualizer/metadata";
+import {
+ GateType,
+ startX,
+ startY,
+ registerHeight,
+ minGateWidth,
+ gatePadding,
+} from "../../ExecutionPathVisualizer/constants";
+
+describe("Testing _classicalControlled", () => {
+ test("one 'zero' child", () => {
+ const metadata: Metadata = {
+ type: GateType.ClassicalControlled,
+ x: startX,
+ controlsY: [startY + registerHeight * 2],
+ targetsY: [startY, startY + registerHeight],
+ width: minGateWidth + gatePadding * 2,
+ label: 'if',
+ children: [
+ [{
+ type: GateType.Unitary,
+ x: startX + minGateWidth / 2 + gatePadding,
+ label: 'X',
+ controlsY: [],
+ targetsY: [startY],
+ width: minGateWidth
+ }],
+ []
+ ],
+ htmlClass: 'cls-control-1'
+ };
+ expect(_classicalControlled(metadata)).toMatchSnapshot();
+ });
+ test("one 'one' child", () => {
+ const metadata: Metadata = {
+ type: GateType.ClassicalControlled,
+ x: startX,
+ controlsY: [startY + registerHeight * 2],
+ targetsY: [startY, startY + registerHeight],
+ width: minGateWidth + gatePadding * 2,
+ label: 'if',
+ children: [
+ [],
+ [{
+ type: GateType.Unitary,
+ x: startX + minGateWidth / 2 + gatePadding,
+ label: 'X',
+ controlsY: [],
+ targetsY: [startY],
+ width: minGateWidth
+ }]
+ ],
+ htmlClass: 'cls-control-1'
+ };
+ expect(_classicalControlled(metadata)).toMatchSnapshot();
+ });
+ test("multiple 'zero'/'one' children", () => {
+ const metadata: Metadata = {
+ type: GateType.ClassicalControlled,
+ x: startX,
+ controlsY: [startY + registerHeight * 2],
+ targetsY: [startY, startY + registerHeight],
+ width: minGateWidth * 2 + gatePadding * 4,
+ label: 'if',
+ htmlClass: 'cls-control-1',
+ children: [
+ [{
+ type: GateType.Unitary,
+ x: startX + minGateWidth / 2 + gatePadding,
+ label: 'X',
+ controlsY: [],
+ targetsY: [startY],
+ width: minGateWidth
+ }],
+ [
+ {
+ type: GateType.Unitary,
+ x: startX + minGateWidth / 2 + gatePadding,
+ label: 'X',
+ controlsY: [],
+ targetsY: [startY],
+ width: minGateWidth
+ },
+ {
+ type: GateType.Cnot,
+ x: startX + minGateWidth + minGateWidth / 2 + gatePadding * 3,
+ label: 'X',
+ controlsY: [startY + registerHeight],
+ targetsY: [startY],
+ width: minGateWidth
+ }
+ ]
+ ],
+ };
+ expect(_classicalControlled(metadata)).toMatchSnapshot();
+ });
+ test("nested children", () => {
+ const metadata: Metadata = {
+ type: GateType.ClassicalControlled,
+ x: startX,
+ controlsY: [startY + registerHeight * 2],
+ targetsY: [startY, startY + registerHeight],
+ width: minGateWidth * 2 + gatePadding * 6,
+ label: 'if',
+ htmlClass: 'cls-control-1',
+ children: [
+ [],
+ [
+ {
+ type: GateType.Unitary,
+ x: startX + minGateWidth / 2 + gatePadding,
+ label: 'X',
+ controlsY: [],
+ targetsY: [startY],
+ width: minGateWidth
+ },
+ {
+ type: GateType.ClassicalControlled,
+ x: startX + minGateWidth + gatePadding * 3,
+ controlsY: [startY + registerHeight * 3],
+ targetsY: [startY, startY + registerHeight],
+ width: minGateWidth + gatePadding * 2,
+ label: 'if',
+ htmlClass: 'cls-control-1',
+ children: [
+ [],
+ [{
+ type: GateType.Cnot,
+ x: startX + minGateWidth + gatePadding * 4 + minGateWidth / 2,
+ label: 'X',
+ controlsY: [startY + registerHeight],
+ targetsY: [startY],
+ width: minGateWidth
+ }]
+ ]
+ }
+ ]
+ ],
+ };
+ expect(_classicalControlled(metadata)).toMatchSnapshot();
+ });
+ test("No htmlClass", () => {
+ const metadata: Metadata = {
+ type: GateType.ClassicalControlled,
+ x: startX,
+ controlsY: [startY + registerHeight * 2],
+ targetsY: [startY, startY + registerHeight],
+ width: minGateWidth * 2 + gatePadding * 4,
+ label: 'if',
+ children: [
+ [],
+ [{
+ type: GateType.Unitary,
+ x: startX + minGateWidth / 2 + gatePadding,
+ label: 'X',
+ controlsY: [],
+ targetsY: [startY],
+ width: minGateWidth
+ }]
+ ],
+ };
+ expect(_classicalControlled(metadata)).toMatchSnapshot();
+ });
+ test("change padding", () => {
+ const metadata: Metadata = {
+ type: GateType.ClassicalControlled,
+ x: startX,
+ controlsY: [startY + registerHeight * 2],
+ targetsY: [startY, startY + registerHeight],
+ width: minGateWidth * 2 + gatePadding * 4,
+ label: 'if',
+ children: [
+ [],
+ [{
+ type: GateType.Unitary,
+ x: startX + minGateWidth / 2 + gatePadding,
+ label: 'X',
+ controlsY: [],
+ targetsY: [startY],
+ width: minGateWidth
+ }]
+ ],
+ htmlClass: 'cls-control-1'
+ };
+ expect(_classicalControlled(metadata, 20)).toMatchSnapshot();
+ });
+});
+
+describe("Testing _controlledGate", () => {
+ test("CNOT gate", () => {
+ const metadata: Metadata = {
+ type: GateType.Cnot,
+ label: 'X',
+ x: startX,
+ controlsY: [startY],
+ targetsY: [startY + registerHeight],
+ width: minGateWidth
+ };
+ let svg: string = _controlledGate(metadata);
+ expect(svg).toMatchSnapshot();
+
+ // Flip target and control
+ metadata.controlsY = [startY + registerHeight];
+ metadata.targetsY = [startY];
+ svg = _controlledGate(metadata);
+ expect(svg).toMatchSnapshot();
+ });
+ test("SWAP gate", () => {
+ const metadata: Metadata = {
+ type: GateType.Swap,
+ label: '',
+ x: startX,
+ controlsY: [startY],
+ targetsY: [startY + registerHeight, startY + registerHeight * 2],
+ width: minGateWidth
+ };
+ // Control on top
+ let svg: string = _controlledGate(metadata);
+ expect(svg).toMatchSnapshot();
+
+ // Control on bottom
+ metadata.controlsY = [startY + registerHeight * 2];
+ metadata.targetsY = [startY, startY + registerHeight];
+ svg = _controlledGate(metadata);
+ expect(svg).toMatchSnapshot();
+
+ // Control in middle
+ metadata.controlsY = [startY + registerHeight];
+ metadata.targetsY = [startY, startY + registerHeight * 2];
+ svg = _controlledGate(metadata);
+ expect(svg).toMatchSnapshot();
+ });
+ test("Controlled U gate with 1 control + 1 target", () => {
+ const metadata: Metadata = {
+ type: GateType.ControlledUnitary,
+ label: 'Foo',
+ x: startX,
+ controlsY: [startY],
+ targetsY: [startY + registerHeight],
+ width: 45
+ };
+ let svg: string = _controlledGate(metadata);
+ expect(svg).toMatchSnapshot();
+
+ // Flip target and control
+ metadata.controlsY = [startY + registerHeight];
+ metadata.targetsY = [startY];
+ svg = _controlledGate(metadata);
+ expect(svg).toMatchSnapshot();
+ });
+ test("Controlled U gate with multiple controls + 1 target", () => {
+ const metadata: Metadata = {
+ type: GateType.ControlledUnitary,
+ label: 'Foo',
+ x: startX,
+ controlsY: [startY, startY + registerHeight],
+ targetsY: [startY + registerHeight * 2],
+ width: 45
+ };
+ // Target on bottom
+ let svg: string = _controlledGate(metadata);
+ expect(svg).toMatchSnapshot();
+
+ // Target on top
+ metadata.controlsY = [startY + registerHeight, startY + registerHeight * 2];
+ metadata.targetsY = [startY];
+ svg = _controlledGate(metadata);
+ expect(svg).toMatchSnapshot();
+
+ // Target in middle
+ metadata.controlsY = [startY, startY + registerHeight * 2];
+ metadata.targetsY = [startY + registerHeight];
+ svg = _controlledGate(metadata);
+ expect(svg).toMatchSnapshot();
+ });
+ test("Controlled U gate with 1 control + 2 targets", () => {
+ const metadata: Metadata = {
+ type: GateType.ControlledUnitary,
+ label: 'Foo',
+ x: startX,
+ controlsY: [startY + registerHeight * 2],
+ targetsY: [startY, startY + registerHeight],
+ width: 45
+ };
+ // Control on bottom
+ let svg: string = _controlledGate(metadata);
+ expect(svg).toMatchSnapshot();
+
+ // Control on top
+ metadata.controlsY = [startY];
+ metadata.targetsY = [startY + registerHeight, startY + registerHeight * 2];
+ svg = _controlledGate(metadata);
+ expect(svg).toMatchSnapshot();
+
+ // Control in middle
+ metadata.controlsY = [startY + registerHeight];
+ metadata.targetsY = [startY, startY + registerHeight * 2];
+ svg = _controlledGate(metadata);
+ expect(svg).toMatchSnapshot();
+ });
+ test("Controlled U gate with 2 controls + 2 targets", () => {
+ const metadata: Metadata = {
+ type: GateType.ControlledUnitary,
+ label: 'Foo',
+ x: startX,
+ controlsY: [startY + registerHeight * 2, startY + registerHeight * 3],
+ targetsY: [startY, startY + registerHeight],
+ width: 45
+ };
+ // Controls on bottom
+ let svg: string = _controlledGate(metadata);
+ expect(svg).toMatchSnapshot();
+
+ // Controls on top
+ metadata.controlsY = [startY, startY + registerHeight];
+ metadata.targetsY = [startY + registerHeight * 2, startY + registerHeight * 3];
+ svg = _controlledGate(metadata);
+ expect(svg).toMatchSnapshot();
+
+ // Controls in middle
+ metadata.controlsY = [startY + registerHeight, startY + registerHeight * 2];
+ metadata.targetsY = [startY, startY + registerHeight * 3];
+ svg = _controlledGate(metadata);
+ expect(svg).toMatchSnapshot();
+
+ // Interleaved controls/targets
+ metadata.controlsY = [startY + registerHeight, startY + registerHeight * 3];
+ metadata.targetsY = [startY, startY + registerHeight * 2];
+ svg = _controlledGate(metadata);
+ expect(svg).toMatchSnapshot();
+ });
+ test("Invalid gate", () => {
+ const metadata: Metadata = {
+ type: GateType.Measure,
+ label: 'X',
+ x: startX,
+ controlsY: [startY],
+ targetsY: [startY + registerHeight],
+ width: minGateWidth
+ };
+ expect(() => _controlledGate(metadata))
+ .toThrowError(`ERROR: Unrecognized gate: X of type ${GateType.Measure}`);
+ });
+});
+
+describe("Testing _swap", () => {
+ test("Adjacent swap", () => {
+ let svg: string = _swap(startX, [startY, startY + registerHeight]);
+ expect(svg).toMatchSnapshot();
+ // Flip target and control
+ svg = _swap(startX, [startY + registerHeight, startY]);
+ expect(svg).toMatchSnapshot();
+ });
+ test("Non-adjacent swap", () => {
+ let svg: string = _swap(startX, [startY, startY + registerHeight * 2]);
+ expect(svg).toMatchSnapshot();
+ // Flip target and control
+ svg = _swap(startX, [startY + registerHeight * 2, startY]);
+ expect(svg).toMatchSnapshot();
+ });
+});
+
+describe("Testing _unitary", () => {
+ test("Single qubit unitary", () => {
+ expect(_unitary('H', startX, [startY], minGateWidth)).toMatchSnapshot();
+ });
+ test("Multiqubit unitary on consecutive registers", () => {
+ let svg: string = _unitary('ZZ', startX, [startY, startY + registerHeight], minGateWidth);
+ expect(svg).toMatchSnapshot();
+ svg = _unitary('ZZZ', startX,
+ [startY, startY + registerHeight, startY + registerHeight * 2], minGateWidth);
+ expect(svg).toMatchSnapshot();
+ });
+ test("Multiqubit unitary on non-consecutive registers", () => {
+ // Dashed line between unitaries
+ let svg: string = _unitary('ZZ', startX, [startY, startY + registerHeight * 2], minGateWidth);
+ expect(svg).toMatchSnapshot();
+ svg = _unitary('ZZZ', startX,
+ [startY, startY + registerHeight * 2, startY + registerHeight * 3], minGateWidth);
+ expect(svg).toMatchSnapshot();
+ // Solid line
+ svg = _unitary('ZZ', startX, [startY, startY + registerHeight * 2], minGateWidth, undefined, false);
+ expect(svg).toMatchSnapshot();
+ svg = _unitary('ZZZ', startX,
+ [startY, startY + registerHeight * 2, startY + registerHeight * 3],
+ minGateWidth, undefined, false);
+ expect(svg).toMatchSnapshot();
+ });
+ test("No y coords", () => {
+ const svg: string = _unitary('ZZ', startX, [], minGateWidth);
+ expect(svg).toStrictEqual("");
+ });
+});
+
+describe("Testing _measure", () => {
+ test("1 qubit + 1 classical registers", () => {
+ expect(_measure(startX, startY, startY + registerHeight))
+ .toMatchSnapshot();
+ });
+ test("2 qubit + 1 classical registers", () => {
+ expect(_measure(startX, startY, startY + registerHeight * 2))
+ .toMatchSnapshot();
+ });
+ test("2 qubit + 2 classical registers", () => {
+ expect(_measure(startX, startY, startY + registerHeight * 3))
+ .toMatchSnapshot();
+ expect(_measure(startX, startY + registerHeight, startY + registerHeight * 3))
+ .toMatchSnapshot();
+ });
+});
+
+describe("Testing _formatGate", () => {
+ test("measure gate", () => {
+ const metadata: Metadata = {
+ type: GateType.Measure,
+ x: startX,
+ controlsY: [startY],
+ targetsY: [startY + registerHeight],
+ label: '',
+ width: minGateWidth,
+ };
+ expect(_formatGate(metadata)).toMatchSnapshot();
+ });
+ test("single-qubit unitary gate", () => {
+ const metadata: Metadata = {
+ type: GateType.Unitary,
+ x: startX,
+ controlsY: [],
+ targetsY: [startY],
+ label: 'H',
+ width: minGateWidth,
+ };
+ expect(_formatGate(metadata)).toMatchSnapshot();
+ });
+ test("single-qubit unitary gate with arguments", () => {
+ const metadata: Metadata = {
+ type: GateType.Unitary,
+ x: startX,
+ controlsY: [],
+ targetsY: [startY],
+ label: 'Ry',
+ displayArgs: '(0.25)',
+ width: 52,
+ };
+ expect(_formatGate(metadata)).toMatchSnapshot();
+ });
+ test("multi-qubit unitary gate", () => {
+ const metadata: Metadata = {
+ type: GateType.Unitary,
+ x: startX,
+ controlsY: [],
+ targetsY: [startY, startY + registerHeight],
+ label: 'U',
+ width: minGateWidth,
+ };
+ expect(_formatGate(metadata)).toMatchSnapshot();
+ });
+
+ test("multi-qubit unitary gate with arguments", () => {
+ const metadata: Metadata = {
+ type: GateType.ControlledUnitary,
+ x: startX,
+ controlsY: [],
+ targetsY: [startY, startY + registerHeight],
+ label: 'U',
+ displayArgs: "('foo', 'bar')",
+ width: 77,
+ };
+ expect(_formatGate(metadata)).toMatchSnapshot();
+ });
+ test("swap gate", () => {
+ const metadata: Metadata = {
+ type: GateType.Swap,
+ x: startX,
+ controlsY: [],
+ targetsY: [startY, startY + registerHeight],
+ label: '',
+ width: minGateWidth,
+ };
+ expect(_formatGate(metadata)).toMatchSnapshot();
+ });
+ test("controlled swap gate", () => {
+ const metadata: Metadata = {
+ type: GateType.Swap,
+ x: startX,
+ controlsY: [startY],
+ targetsY: [startY + registerHeight, startY + registerHeight * 2],
+ label: '',
+ width: minGateWidth,
+ };
+ expect(_formatGate(metadata)).toMatchSnapshot();
+ });
+ test("CNOT gate", () => {
+ const metadata: Metadata = {
+ type: GateType.Cnot,
+ x: startX,
+ controlsY: [startY],
+ targetsY: [startY + registerHeight],
+ label: 'X',
+ width: minGateWidth,
+ };
+ expect(_formatGate(metadata)).toMatchSnapshot();
+ });
+ test("controlled unitary gate", () => {
+ const metadata: Metadata = {
+ type: GateType.ControlledUnitary,
+ x: startX,
+ controlsY: [startY],
+ targetsY: [startY + registerHeight],
+ label: 'U',
+ width: minGateWidth,
+ };
+ expect(_formatGate(metadata)).toMatchSnapshot();
+ });
+ test("controlled unitary gate with arguments", () => {
+ const metadata: Metadata = {
+ type: GateType.ControlledUnitary,
+ x: startX,
+ controlsY: [startY],
+ targetsY: [startY + registerHeight],
+ label: 'U',
+ displayArgs: "('foo', 'bar')",
+ width: 77,
+ };
+ expect(_formatGate(metadata)).toMatchSnapshot();
+ });
+ test("classically controlled gate", () => {
+ const metadata: Metadata = {
+ type: GateType.ClassicalControlled,
+ x: startX,
+ controlsY: [startY + registerHeight * 2],
+ targetsY: [startY, startY + registerHeight],
+ label: '',
+ width: minGateWidth,
+ };
+ expect(_formatGate(metadata)).toMatchSnapshot();
+ });
+ test("Invalid gate", () => {
+ const metadata: Metadata = {
+ type: GateType.Invalid,
+ x: startX,
+ controlsY: [startY],
+ targetsY: [startY + registerHeight],
+ label: 'Foo',
+ width: 48,
+ };
+ expect(() => _formatGate(metadata))
+ .toThrowError(`ERROR: unknown gate (Foo) of type ${GateType.Invalid}.`);
+ });
+});
+
+describe("Testing formatGates", () => {
+ test("Single gate", () => {
+ const gates: Metadata[] = [
+ {
+ type: GateType.Cnot,
+ x: startX,
+ controlsY: [startY],
+ targetsY: [startY + registerHeight],
+ label: 'X',
+ width: minGateWidth,
+ },
+ ];
+ expect(formatGates(gates)).toMatchSnapshot();
+ });
+ test("Single null gate", () => {
+ const gates: Metadata[] = [
+ {
+ type: GateType.Invalid,
+ x: startX,
+ controlsY: [startY],
+ targetsY: [startY + registerHeight],
+ label: '',
+ width: minGateWidth,
+ },
+ ];
+ expect(() => formatGates(gates)).toThrowError(`ERROR: unknown gate () of type ${GateType.Invalid}.`);
+ });
+ test("Multiple gates", () => {
+ const gates: Metadata[] = [
+ {
+ type: GateType.Cnot,
+ x: startX,
+ controlsY: [startY + registerHeight],
+ targetsY: [startY],
+ label: 'X',
+ width: minGateWidth,
+ },
+ {
+ type: GateType.ControlledUnitary,
+ x: startX,
+ controlsY: [startY + registerHeight],
+ targetsY: [startY + registerHeight * 2],
+ label: 'X',
+ width: minGateWidth,
+ },
+ {
+ type: GateType.Unitary,
+ x: startX,
+ controlsY: [],
+ targetsY: [startY + registerHeight * 2],
+ label: 'X',
+ width: minGateWidth,
+ },
+ {
+ type: GateType.Measure,
+ x: startX,
+ controlsY: [startY],
+ targetsY: [startY + registerHeight * 3],
+ label: 'X',
+ width: minGateWidth,
+ },
+ ];
+ expect(formatGates(gates)).toMatchSnapshot();
+ });
+ test("Multiple gates with invalid gate", () => {
+ const gates: Metadata[] = [
+ {
+ type: GateType.Unitary,
+ x: startX,
+ controlsY: [],
+ targetsY: [startY + registerHeight * 2],
+ label: 'X',
+ width: minGateWidth,
+ },
+ {
+ type: GateType.Cnot,
+ x: startX,
+ controlsY: [startY + registerHeight],
+ targetsY: [startY],
+ label: 'X',
+ width: minGateWidth,
+ },
+ {
+ type: GateType.Invalid,
+ x: startX,
+ controlsY: [],
+ targetsY: [startY + registerHeight * 2],
+ label: '',
+ width: minGateWidth,
+ },
+ {
+ type: GateType.Invalid,
+ x: startX,
+ controlsY: [],
+ targetsY: [],
+ label: '',
+ width: minGateWidth,
+ },
+ ];
+ expect(() => formatGates(gates))
+ .toThrowError(`ERROR: unknown gate () of type ${GateType.Invalid}.`);
+ });
+});
diff --git a/src/Kernel/client/__tests__/ExecutionPathVisualizerTests/inputFormatter.test.ts b/src/Kernel/client/__tests__/ExecutionPathVisualizerTests/inputFormatter.test.ts
new file mode 100644
index 0000000000..c6c7971876
--- /dev/null
+++ b/src/Kernel/client/__tests__/ExecutionPathVisualizerTests/inputFormatter.test.ts
@@ -0,0 +1,86 @@
+import { Qubit } from "../../ExecutionPathVisualizer/executionPath";
+import { RegisterMap, RegisterType } from "../../ExecutionPathVisualizer/register";
+import { formatInputs, _qubitInput } from "../../ExecutionPathVisualizer/formatters/inputFormatter";
+import { startY, registerHeight, classicalRegHeight } from "../../ExecutionPathVisualizer/constants";
+
+describe("Testing _qubitInput", () => {
+ test("classical register", () => {
+ expect(_qubitInput(20)).toMatchSnapshot();
+ expect(_qubitInput(50)).toMatchSnapshot();
+ expect(_qubitInput(0)).toMatchSnapshot();
+ });
+});
+
+describe("Testing formatInputs", () => {
+ test("1 quantum register", () => {
+ const inputs: Qubit[] = [{ id: 0 }];
+ const expectedRegs: RegisterMap = { 0: { type: RegisterType.Qubit, y: startY } };
+ const { qubitWires, registers } = formatInputs(inputs);
+ expect(qubitWires).toMatchSnapshot();
+ expect(registers).toEqual(expectedRegs);
+ expect(registers).toEqual(expectedRegs);
+ });
+ test("Multiple quantum registers", () => {
+ const inputs: Qubit[] = [{ id: 0 }, { id: 1 }, { id: 2 }];
+ const expectedRegs: RegisterMap = {
+ 0: { type: RegisterType.Qubit, y: startY },
+ 1: { type: RegisterType.Qubit, y: startY + registerHeight },
+ 2: { type: RegisterType.Qubit, y: startY + registerHeight * 2 },
+ };
+ const { qubitWires, registers } = formatInputs(inputs);
+ expect(qubitWires).toMatchSnapshot();
+ expect(registers).toEqual(expectedRegs);
+ expect(registers).toEqual(expectedRegs);
+ });
+ test("Quantum and classical registers", () => {
+ let inputs: Qubit[] = [{ id: 0, numChildren: 1 }, { id: 1 }, { id: 2 }];
+ let expectedRegs: RegisterMap = {
+ 0: {
+ type: RegisterType.Qubit,
+ y: startY,
+ children: [{ type: RegisterType.Classical, y: startY + classicalRegHeight }]
+ },
+ 1: { type: RegisterType.Qubit, y: startY + classicalRegHeight * 2 },
+ 2: { type: RegisterType.Qubit, y: startY + registerHeight + classicalRegHeight * 2 },
+ };
+ let { qubitWires, registers } = formatInputs(inputs);
+ expect(qubitWires).toMatchSnapshot();
+ expect(registers).toEqual(expectedRegs);
+ expect(registers).toEqual(expectedRegs);
+
+ inputs = [{ id: 0 }, { id: 1, numChildren: 2 }, { id: 2, numChildren: 1 }];
+ expectedRegs = {
+ 0: { type: RegisterType.Qubit, y: startY },
+ 1: {
+ type: RegisterType.Qubit,
+ y: startY + registerHeight,
+ children: [
+ { type: RegisterType.Classical, y: startY + registerHeight + classicalRegHeight },
+ { type: RegisterType.Classical, y: startY + registerHeight + classicalRegHeight * 2 },
+ ]
+ },
+ 2: {
+ type: RegisterType.Qubit,
+ y: startY + registerHeight + classicalRegHeight * 3,
+ children: [
+ { type: RegisterType.Classical, y: startY + registerHeight + classicalRegHeight * 4 },
+ ]
+ },
+ };
+ ({ qubitWires, registers } = formatInputs(inputs));
+ expect(qubitWires).toMatchSnapshot();
+ expect(registers).toEqual(expectedRegs);
+ expect(registers).toEqual(expectedRegs);
+ });
+ test("Skip quantum registers", () => {
+ const inputs: Qubit[] = [{ id: 0 }, { id: 2 }];
+ const expectedRegs: RegisterMap = {
+ 0: { type: RegisterType.Qubit, y: startY },
+ 2: { type: RegisterType.Qubit, y: startY + registerHeight },
+ };
+ const { qubitWires, registers } = formatInputs(inputs);
+ expect(qubitWires).toMatchSnapshot();
+ expect(registers).toEqual(expectedRegs);
+ expect(registers).toEqual(expectedRegs);
+ });
+});
diff --git a/src/Kernel/client/__tests__/ExecutionPathVisualizerTests/process.test.ts b/src/Kernel/client/__tests__/ExecutionPathVisualizerTests/process.test.ts
new file mode 100644
index 0000000000..ece1c6ed4d
--- /dev/null
+++ b/src/Kernel/client/__tests__/ExecutionPathVisualizerTests/process.test.ts
@@ -0,0 +1,1536 @@
+import { Operation } from "../../ExecutionPathVisualizer/executionPath";
+import { RegisterMap, RegisterType, Register } from "../../ExecutionPathVisualizer/register";
+import { Metadata } from "../../ExecutionPathVisualizer/metadata";
+import {
+ processOperations,
+ _groupOperations,
+ _alignOps,
+ _getColumnsX,
+ _opToMetadata,
+ _getRegY,
+ _addClass,
+ _fillMetadataX,
+ _offsetChildrenX,
+} from "../../ExecutionPathVisualizer/process";
+import {
+ GateType,
+ minGateWidth,
+ startX,
+ startY,
+ registerHeight,
+ gatePadding,
+ classicalRegHeight,
+ controlBtnOffset,
+ classicalBoxPadding
+} from "../../ExecutionPathVisualizer/constants";
+import { _getStringWidth } from "../../ExecutionPathVisualizer/utils";
+
+describe("Testing _groupOperations", () => {
+ const registers: RegisterMap = {
+ 0: { type: RegisterType.Qubit, y: startY },
+ 1: { type: RegisterType.Qubit, y: startY + registerHeight },
+ 2: { type: RegisterType.Qubit, y: startY + registerHeight * 2 },
+ 3: { type: RegisterType.Qubit, y: startY + registerHeight * 3 },
+ };
+ test("single qubit gates on 1 qubit register", () => {
+ const operations: Operation[] = [
+ { gate: "X", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 0 }] },
+ { gate: "Y", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 0 }] },
+ { gate: "Z", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 0 }] },
+ ];
+ expect(_groupOperations(operations, registers)).toEqual([[0, 1, 2], [], [], []]);
+ });
+ test("single qubit gates on multiple qubit registers", () => {
+ const operations: Operation[] = [
+ { gate: "X", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 0 }] },
+ { gate: "Y", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 1 }] },
+ { gate: "Z", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 2 }] },
+ { gate: "H", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 0 }] },
+ { gate: "T", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 1 }] },
+ ];
+ expect(_groupOperations(operations, registers)).toEqual([[0, 3], [1, 4], [2], []]);
+ });
+ test("single and multiple qubit(s) gates", () => {
+ let operations: Operation[] = [
+ { gate: "X", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 0 }] },
+ { gate: "Y", isMeasurement: false, isControlled: true, isAdjoint: false, controls: [{ type: RegisterType.Qubit, qId: 0 }], targets: [{ type: RegisterType.Qubit, qId: 1 }] },
+ { gate: "Z", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 0 }] },
+ ];
+ expect(_groupOperations(operations, registers)).toEqual([[0, 1, 2], [1], [], []]);
+ operations = [
+ { gate: "X", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 0 }] },
+ { gate: "Y", isMeasurement: false, isControlled: true, isAdjoint: false, controls: [{ type: RegisterType.Qubit, qId: 1 }], targets: [{ type: RegisterType.Qubit, qId: 0 }] },
+ { gate: "Z", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 0 }] },
+ ];
+ expect(_groupOperations(operations, registers)).toEqual([[0, 1, 2], [1], [], []]);
+ operations = [
+ { gate: "X", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 0 }] },
+ { gate: "Z", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 0 }] },
+ { gate: "Y", isMeasurement: false, isControlled: true, isAdjoint: false, controls: [{ type: RegisterType.Qubit, qId: 1 }], targets: [{ type: RegisterType.Qubit, qId: 0 }] },
+ ];
+ expect(_groupOperations(operations, registers)).toEqual([[0, 1, 2], [2], [], []]);
+ operations = [
+ { gate: "Y", isMeasurement: false, isControlled: true, isAdjoint: false, controls: [{ type: RegisterType.Qubit, qId: 1 }], targets: [{ type: RegisterType.Qubit, qId: 0 }] },
+ { gate: "X", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 0 }] },
+ { gate: "Z", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 0 }] },
+ ];
+ expect(_groupOperations(operations, registers)).toEqual([[0, 1, 2], [0], [], []]);
+ operations = [
+ { gate: "Y", isMeasurement: false, isControlled: true, isAdjoint: false, controls: [{ type: RegisterType.Qubit, qId: 1 }], targets: [{ type: RegisterType.Qubit, qId: 0 }] },
+ { gate: "X", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 0 }] },
+ { gate: "Z", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 1 }] },
+ ];
+ expect(_groupOperations(operations, registers)).toEqual([[0, 1], [0, 2], [], []]);
+ });
+ test("multiple qubit gates in ladder format", () => {
+ const operations: Operation[] = [
+ { gate: "X", isMeasurement: false, isControlled: true, isAdjoint: false, controls: [{ type: RegisterType.Qubit, qId: 1 }], targets: [{ type: RegisterType.Qubit, qId: 0 }] },
+ { gate: "Y", isMeasurement: false, isControlled: true, isAdjoint: false, controls: [{ type: RegisterType.Qubit, qId: 1 }], targets: [{ type: RegisterType.Qubit, qId: 2 }] },
+ { gate: "Z", isMeasurement: false, isControlled: true, isAdjoint: false, controls: [{ type: RegisterType.Qubit, qId: 2 }], targets: [{ type: RegisterType.Qubit, qId: 3 }] },
+ { gate: "H", isMeasurement: false, isControlled: true, isAdjoint: false, controls: [{ type: RegisterType.Qubit, qId: 2 }], targets: [{ type: RegisterType.Qubit, qId: 3 }] },
+ { gate: "T", isMeasurement: false, isControlled: true, isAdjoint: false, controls: [{ type: RegisterType.Qubit, qId: 2 }], targets: [{ type: RegisterType.Qubit, qId: 1 }] },
+ { gate: "X", isMeasurement: false, isControlled: true, isAdjoint: false, controls: [{ type: RegisterType.Qubit, qId: 0 }], targets: [{ type: RegisterType.Qubit, qId: 1 }] },
+ ];
+ expect(_groupOperations(operations, registers)).toEqual([[0, 5], [0, 1, 4, 5], [1, 2, 3, 4], [2, 3]]);
+
+ });
+ test("multiple qubit gates in ladder format with single qubit gate", () => {
+ let numRegs: number = 4;
+ let operations: Operation[] = [
+ { gate: "X", isMeasurement: false, isControlled: true, isAdjoint: false, controls: [{ type: RegisterType.Qubit, qId: 1 }], targets: [{ type: RegisterType.Qubit, qId: 0 }] },
+ { gate: "Y", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 1 }] },
+ { gate: "Y", isMeasurement: false, isControlled: true, isAdjoint: false, controls: [{ type: RegisterType.Qubit, qId: 1 }], targets: [{ type: RegisterType.Qubit, qId: 2 }] },
+ { gate: "Z", isMeasurement: false, isControlled: true, isAdjoint: false, controls: [{ type: RegisterType.Qubit, qId: 2 }], targets: [{ type: RegisterType.Qubit, qId: 3 }] },
+ { gate: "Z", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 2 }] },
+ { gate: "H", isMeasurement: false, isControlled: true, isAdjoint: false, controls: [{ type: RegisterType.Qubit, qId: 2 }], targets: [{ type: RegisterType.Qubit, qId: 3 }] },
+ { gate: "T", isMeasurement: false, isControlled: true, isAdjoint: false, controls: [{ type: RegisterType.Qubit, qId: 2 }], targets: [{ type: RegisterType.Qubit, qId: 1 }] },
+ { gate: "Y", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 1 }] },
+ { gate: "X", isMeasurement: false, isControlled: true, isAdjoint: false, controls: [{ type: RegisterType.Qubit, qId: 0 }], targets: [{ type: RegisterType.Qubit, qId: 1 }] },
+ ];
+ expect(_groupOperations(operations, registers)).toEqual([[0, 8], [0, 1, 2, 6, 7, 8], [2, 3, 4, 5, 6], [3, 5]]);
+
+ numRegs = 3;
+ operations = [
+ { gate: "X", isMeasurement: false, isControlled: true, isAdjoint: false, controls: [{ type: RegisterType.Qubit, qId: 1 }], targets: [{ type: RegisterType.Qubit, qId: 0 }] },
+ { gate: "Y", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 1 }] },
+ { gate: "Y", isMeasurement: false, isControlled: true, isAdjoint: false, controls: [{ type: RegisterType.Qubit, qId: 1 }], targets: [{ type: RegisterType.Qubit, qId: 2 }] },
+ { gate: "Z", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 2 }] },
+ { gate: "T", isMeasurement: false, isControlled: true, isAdjoint: false, controls: [{ type: RegisterType.Qubit, qId: 2 }], targets: [{ type: RegisterType.Qubit, qId: 1 }] },
+ { gate: "Y", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 1 }] },
+ { gate: "H", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 0 }] },
+ { gate: "H", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 0 }] },
+ { gate: "H", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 0 }] },
+ { gate: "H", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 0 }] },
+ { gate: "X", isMeasurement: false, isControlled: true, isAdjoint: false, controls: [{ type: RegisterType.Qubit, qId: 0 }], targets: [{ type: RegisterType.Qubit, qId: 1 }] },
+ ];
+ expect(_groupOperations(operations, registers)).toEqual([[0, 6, 7, 8, 9, 10], [0, 1, 2, 4, 5, 10], [2, 3, 4], []]);
+ });
+ test("interleaved multiqubit gates", () => {
+ let operations: Operation[] = [
+ { gate: "X", isMeasurement: false, isControlled: true, isAdjoint: false, controls: [{ type: RegisterType.Qubit, qId: 1 }], targets: [{ type: RegisterType.Qubit, qId: 3 }] },
+ { gate: "X", isMeasurement: false, isControlled: true, isAdjoint: false, controls: [{ type: RegisterType.Qubit, qId: 0 }], targets: [{ type: RegisterType.Qubit, qId: 2 }] },
+ ];
+ expect(_groupOperations(operations, registers)).toEqual([[1], [0, 1], [0, 1], [0]]);
+ operations = [
+ { gate: "X", isMeasurement: false, isControlled: true, isAdjoint: false, controls: [{ type: RegisterType.Qubit, qId: 0 }, { type: RegisterType.Qubit, qId: 1 }], targets: [{ type: RegisterType.Qubit, qId: 3 }] },
+ { gate: "X", isMeasurement: false, isControlled: true, isAdjoint: false, controls: [{ type: RegisterType.Qubit, qId: 0 }], targets: [{ type: RegisterType.Qubit, qId: 2 }, { type: RegisterType.Qubit, qId: 3 }] },
+ ];
+ expect(_groupOperations(operations, registers)).toEqual([[0, 1], [0, 1], [0, 1], [0, 1]]);
+ operations = [
+ { gate: "Foo", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 0 }, { type: RegisterType.Qubit, qId: 2 }, { type: RegisterType.Qubit, qId: 3 }] },
+ { gate: "Bar", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 0 }, { type: RegisterType.Qubit, qId: 1 }, { type: RegisterType.Qubit, qId: 2 }] },
+ ];
+ expect(_groupOperations(operations, registers)).toEqual([[0, 1], [0, 1], [0, 1], [0]]);
+ });
+ test("classical control gates", () => {
+ const registers: RegisterMap = {
+ 0: { type: RegisterType.Qubit, y: startY },
+ 1: {
+ type: RegisterType.Qubit,
+ y: startY + registerHeight,
+ children: [{ type: RegisterType.Classical, y: startY + registerHeight + classicalRegHeight }]
+ },
+ 2: {
+ type: RegisterType.Qubit,
+ y: startY + registerHeight + classicalRegHeight * 2,
+ children: [{ type: RegisterType.Classical, y: startY + registerHeight + classicalRegHeight * 3 }]
+ },
+ 3: { type: RegisterType.Qubit, y: startY + registerHeight + classicalRegHeight * 4 },
+ }
+ let operations: Operation[] = [
+ { gate: "X", isMeasurement: false, isControlled: true, isAdjoint: false, controls: [{ type: RegisterType.Classical, qId: 2, cId: 0 }], targets: [{ type: RegisterType.Qubit, qId: 1 }] },
+ { gate: "X", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 0 }] },
+ ];
+ expect(_groupOperations(operations, registers)).toEqual([[0, 1], [0], [0], [0]]);
+ operations = [
+ { gate: "X", isMeasurement: false, isControlled: true, isAdjoint: false, controls: [{ type: RegisterType.Classical, qId: 2, cId: 0 }], targets: [{ type: RegisterType.Qubit, qId: 0 }] },
+ { gate: "X", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 1 }] },
+ ];
+ expect(_groupOperations(operations, registers)).toEqual([[0], [0, 1], [0], [0]]);
+ operations = [
+ { gate: "X", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 1 }] },
+ { gate: "X", isMeasurement: false, isControlled: true, isAdjoint: false, controls: [{ type: RegisterType.Classical, qId: 1, cId: 0 }], targets: [{ type: RegisterType.Qubit, qId: 0 }] },
+ ];
+ expect(_groupOperations(operations, registers)).toEqual([[1], [0, 1], [1], [1]]);
+ });
+ test("skipped registers", () => {
+ let operations: Operation[] = [
+ { gate: "X", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 0 }] },
+ { gate: "Z", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [{ type: RegisterType.Qubit, qId: 2 }] },
+ ];
+ expect(_groupOperations(operations, registers)).toEqual([[0], [], [1], []]);
+ operations = [
+ { gate: "X", isMeasurement: false, isControlled: true, isAdjoint: false, controls: [{ type: RegisterType.Qubit, qId: 1 }], targets: [{ type: RegisterType.Qubit, qId: 0 }] },
+ { gate: "Z", isMeasurement: false, isControlled: true, isAdjoint: false, controls: [{ type: RegisterType.Qubit, qId: 1 }], targets: [{ type: RegisterType.Qubit, qId: 2 }] },
+ ];
+ expect(_groupOperations(operations, registers)).toEqual([[0], [0, 1], [1], []]);
+ });
+ test("no qubits", () => {
+ const operations: Operation[] = [
+ { gate: "NoOp1", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [] },
+ { gate: "NoOp2", isMeasurement: false, isControlled: false, isAdjoint: false, controls: [], targets: [] },
+ ];
+ expect(_groupOperations(operations, registers)).toEqual([[], [], [], []]);
+ });
+});
+
+describe("Testing _alignOps", () => {
+ test("single qubit gates", () => {
+ const ops: number[][] = [[0, 2, 5, 6], [1, 3, 4]];
+ expect(_alignOps(ops)).toEqual(ops);
+ });
+ test("correct ordering of single qubit gate after multiqubit gate", () => {
+ const ops: number[][] = [[0, 1, 3], [1, 2]];
+ expect(_alignOps(ops)).toEqual([[0, 1, 3], [null, 1, 2]]);
+ });
+ test("padding of multiqubit register after single qubit gate", () => {
+ const ops: number[][] = [[1], [0, 1]];
+ expect(_alignOps(ops)).toEqual([[null, 1], [0, 1]]);
+ });
+ test("no padding of single qubit gate after multiqubit gate on different registers", () => {
+ const ops: number[][] = [[0, 3], [2], [1, 2]];
+ expect(_alignOps(ops)).toEqual([[0, 3], [null, 2], [1, 2]]);
+ });
+ test("ladder of cnots", () => {
+ const ops: number[][] = [[0, 4], [0, 1, 3, 4], [1, 2, 3]];
+ expect(_alignOps(ops)).toEqual([[0, null, null, null, 4], [0, 1, null, 3, 4], [null, 1, 2, 3]]);
+ });
+ test("interleaved multiqubit gates", () => {
+ let ops: number[][] = [[0], [0, 1], [0, 1], [1]];
+ expect(_alignOps(ops)).toEqual([[0], [0, 1], [0, 1], [null, 1]]);
+ ops = [[0], [0], [0, 1], [1], [1], [1]];
+ expect(_alignOps(ops)).toEqual([[0], [0], [0, 1], [null, 1], [null, 1], [null, 1]]);
+ });
+ test("skipped registers", () => {
+ let ops: number[][] = [[0], [], [1], []];
+ expect(_alignOps(ops)).toEqual([[0], [], [1], []]);
+ ops = [[0], [], [1, 2], [2]];
+ expect(_alignOps(ops)).toEqual([[0], [], [1, 2], [null, 2]]);
+ });
+});
+
+describe("Testing _getColumnsX", () => {
+ test("0 columns", () =>
+ expect(_getColumnsX([])).toEqual({ columnsX: [], svgWidth: startX }));
+ test("1 column", () => {
+ expect(_getColumnsX([minGateWidth]))
+ .toEqual({
+ columnsX: [startX + minGateWidth / 2],
+ svgWidth: startX + minGateWidth + gatePadding * 2
+ });
+ expect(_getColumnsX([100]))
+ .toEqual({
+ columnsX: [startX + 100 / 2],
+ svgWidth: startX + 100 + gatePadding * 2
+ });
+ });
+ test("2 columns", () => {
+ expect(_getColumnsX([10, 10]))
+ .toEqual({
+ columnsX: [startX + 5, startX + 15 + gatePadding * 2],
+ svgWidth: startX + 20 + gatePadding * 4
+ });
+ expect(_getColumnsX([20, 10]))
+ .toEqual({
+ columnsX: [startX + 10, startX + 25 + gatePadding * 2],
+ svgWidth: startX + 30 + gatePadding * 4
+ });
+ });
+});
+
+describe("Testing _opToMetadata", () => {
+ test("single qubit gate", () => {
+ const op: Operation = {
+ gate: "X",
+ isMeasurement: false,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [],
+ targets: [{ type: RegisterType.Qubit, qId: 1 }]
+ };
+ const registers: RegisterMap = {
+ 0: { type: RegisterType.Qubit, y: startY },
+ 1: { type: RegisterType.Qubit, y: startY + registerHeight },
+ };
+ const metadata: Metadata = {
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [startY + registerHeight],
+ label: 'X',
+ width: minGateWidth
+ };
+ expect(_opToMetadata(op, registers)).toEqual(metadata);
+ });
+ test("isAdjoint gate", () => {
+ const op: Operation = {
+ gate: "Foo",
+ isMeasurement: false,
+ isControlled: false,
+ isAdjoint: true,
+ controls: [],
+ targets: [{ type: RegisterType.Qubit, qId: 1 }]
+ };
+ const registers: RegisterMap = {
+ 0: { type: RegisterType.Qubit, y: startY },
+ 1: { type: RegisterType.Qubit, y: startY + registerHeight },
+ };
+ const metadata: Metadata = {
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [startY + registerHeight],
+ label: "Foo'",
+ width: 48
+ };
+ expect(_opToMetadata(op, registers)).toEqual(metadata);
+ });
+ test("measure gate", () => {
+ const op: Operation = {
+ gate: "M",
+ isMeasurement: true,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [{ type: RegisterType.Qubit, qId: 0 }],
+ targets: [{ type: RegisterType.Classical, qId: 0, cId: 0 }]
+ };
+ const registers: RegisterMap = {
+ 0: { type: RegisterType.Qubit, y: startY, children: [{ type: RegisterType.Classical, y: startY + classicalRegHeight }] },
+ };
+ const metadata: Metadata = {
+ type: GateType.Measure,
+ x: 0,
+ controlsY: [startY],
+ targetsY: [startY + classicalRegHeight],
+ label: '',
+ width: minGateWidth
+ };
+ expect(_opToMetadata(op, registers)).toEqual(metadata);
+ });
+ test("swap gate", () => {
+ const op: Operation = {
+ gate: "SWAP",
+ isMeasurement: false,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [],
+ targets: [
+ { type: RegisterType.Qubit, qId: 0 },
+ { type: RegisterType.Qubit, qId: 1 }
+ ]
+ };
+ const registers: RegisterMap = {
+ 0: { type: RegisterType.Qubit, y: startY },
+ 1: { type: RegisterType.Qubit, y: startY + registerHeight },
+ };
+ const metadata: Metadata = {
+ type: GateType.Swap,
+ x: 0,
+ controlsY: [],
+ targetsY: [startY, startY + registerHeight],
+ label: '',
+ width: minGateWidth
+ };
+ expect(_opToMetadata(op, registers)).toEqual(metadata);
+ });
+ test("isControlled swap gate", () => {
+ const op: Operation = {
+ gate: "SWAP",
+ isMeasurement: false,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [{ type: RegisterType.Qubit, qId: 0 }],
+ targets: [
+ { type: RegisterType.Qubit, qId: 1 },
+ { type: RegisterType.Qubit, qId: 2 }
+ ]
+ };
+ const registers: RegisterMap = {
+ 0: { type: RegisterType.Qubit, y: startY },
+ 1: { type: RegisterType.Qubit, y: startY + registerHeight },
+ 2: { type: RegisterType.Qubit, y: startY + registerHeight * 2 },
+ };
+ const metadata: Metadata = {
+ type: GateType.Swap,
+ x: 0,
+ controlsY: [startY],
+ targetsY: [startY + registerHeight, startY + registerHeight * 2],
+ label: '',
+ width: minGateWidth
+ };
+ expect(_opToMetadata(op, registers)).toEqual(metadata);
+ });
+ test("single qubit unitary gate", () => {
+ const op: Operation = {
+ gate: "X",
+ isMeasurement: false,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [],
+ targets: [{ type: RegisterType.Qubit, qId: 0 }]
+ };
+ const registers: RegisterMap = {
+ 0: { type: RegisterType.Qubit, y: startY },
+ };
+ const metadata: Metadata = {
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [startY],
+ label: 'X',
+ width: minGateWidth
+ };
+ expect(_opToMetadata(op, registers)).toEqual(metadata);
+ });
+ test("multiqubit unitary gate", () => {
+ const registers: RegisterMap = {
+ 0: { type: RegisterType.Qubit, y: startY },
+ 1: { type: RegisterType.Qubit, y: startY + registerHeight },
+ 2: { type: RegisterType.Qubit, y: startY + registerHeight * 2 },
+ };
+ let op: Operation = {
+ gate: "ZZ",
+ isMeasurement: false,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [],
+ targets: [
+ { type: RegisterType.Qubit, qId: 0 },
+ { type: RegisterType.Qubit, qId: 1 }
+ ]
+ };
+ let metadata: Metadata = {
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [startY, startY + registerHeight],
+ label: 'ZZ',
+ width: minGateWidth
+ };
+ expect(_opToMetadata(op, registers)).toEqual(metadata);
+ op = {
+ gate: "XX",
+ isMeasurement: false,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [],
+ targets: [
+ { type: RegisterType.Qubit, qId: 1 },
+ { type: RegisterType.Qubit, qId: 2 },
+ ]
+ };
+ metadata = {
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [startY + registerHeight, startY + registerHeight * 2],
+ label: 'XX',
+ width: minGateWidth
+ };
+ expect(_opToMetadata(op, registers)).toEqual(metadata);
+ });
+ test("isControlled unitary gates", () => {
+ const registers: RegisterMap = {
+ 0: { type: RegisterType.Qubit, y: startY },
+ 1: { type: RegisterType.Qubit, y: startY + registerHeight },
+ 2: { type: RegisterType.Qubit, y: startY + registerHeight * 2 },
+ 3: { type: RegisterType.Qubit, y: startY + registerHeight * 3 },
+ };
+ let op: Operation = {
+ gate: "ZZ",
+ isMeasurement: false,
+ isControlled: true,
+ isAdjoint: false,
+ controls: [{ type: RegisterType.Qubit, qId: 1 }],
+ targets: [{ type: RegisterType.Qubit, qId: 0 }]
+ };
+ let metadata: Metadata = {
+ type: GateType.ControlledUnitary,
+ x: 0,
+ controlsY: [startY + registerHeight],
+ targetsY: [startY],
+ label: 'ZZ',
+ width: minGateWidth
+ };
+ expect(_opToMetadata(op, registers)).toEqual(metadata);
+ op = {
+ gate: "XX",
+ isMeasurement: false,
+ isControlled: true,
+ isAdjoint: false,
+ controls: [{ type: RegisterType.Qubit, qId: 0 }],
+ targets: [
+ { type: RegisterType.Qubit, qId: 1 },
+ { type: RegisterType.Qubit, qId: 2 },
+ ]
+ };
+ metadata = {
+ type: GateType.ControlledUnitary,
+ x: 0,
+ controlsY: [startY],
+ targetsY: [startY + registerHeight, startY + registerHeight * 2],
+ label: 'XX',
+ width: minGateWidth
+ };
+ expect(_opToMetadata(op, registers)).toEqual(metadata);
+ op = {
+ gate: "Foo",
+ isMeasurement: false,
+ isControlled: true,
+ isAdjoint: false,
+ controls: [
+ { type: RegisterType.Qubit, qId: 2 },
+ { type: RegisterType.Qubit, qId: 3 },
+ ],
+ targets: [
+ { type: RegisterType.Qubit, qId: 0 },
+ { type: RegisterType.Qubit, qId: 1 },
+ ]
+ };
+ metadata = {
+ type: GateType.ControlledUnitary,
+ label: 'Foo',
+ x: 0,
+ controlsY: [startY + registerHeight * 2, startY + registerHeight * 3],
+ targetsY: [startY, startY + registerHeight],
+ width: 45
+ };
+ expect(_opToMetadata(op, registers)).toEqual(metadata);
+ });
+ test("single-qubit unitary gates with arguments", () => {
+ const registers: RegisterMap = {
+ 0: { type: RegisterType.Qubit, y: startY },
+ 1: { type: RegisterType.Qubit, y: startY + registerHeight },
+ };
+ let op: Operation = {
+ gate: "RX",
+ displayArgs: "(0.25)",
+ isMeasurement: false,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [],
+ targets: [{ type: RegisterType.Qubit, qId: 0 }]
+ };
+ let metadata: Metadata = {
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [startY],
+ label: "RX",
+ displayArgs: "(0.25)",
+ width: 52
+ };
+ expect(_opToMetadata(op, registers)).toEqual(metadata);
+
+ // Test long argument
+ op = {
+ gate: "RX",
+ displayArgs: "(0.25, 1.0, 'foobar', (3.14, 6.67))",
+ isMeasurement: false,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [],
+ targets: [{ type: RegisterType.Qubit, qId: 0 }]
+ };
+ metadata = {
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [startY],
+ label: "RX",
+ displayArgs: "(0.25, 1.0, 'foobar', (3.14, 6.67))",
+ width: 188
+ };
+ expect(_opToMetadata(op, registers)).toEqual(metadata);
+
+ // Test isControlled
+ op = {
+ gate: "RX",
+ displayArgs: "(0.25)",
+ isMeasurement: false,
+ isControlled: true,
+ isAdjoint: false,
+ controls: [{ type: RegisterType.Qubit, qId: 1 }],
+ targets: [{ type: RegisterType.Qubit, qId: 0 }]
+ };
+ metadata = {
+ type: GateType.ControlledUnitary,
+ x: 0,
+ controlsY: [startY + registerHeight],
+ targetsY: [startY],
+ label: "RX",
+ displayArgs: "(0.25)",
+ width: 52
+ };
+ expect(_opToMetadata(op, registers)).toEqual(metadata);
+ });
+ test("multi-qubit unitary gates with arguments", () => {
+ const registers: RegisterMap = {
+ 0: { type: RegisterType.Qubit, y: startY },
+ 1: { type: RegisterType.Qubit, y: startY + registerHeight },
+ 2: { type: RegisterType.Qubit, y: startY + registerHeight * 2 },
+ };
+ let op: Operation = {
+ gate: "U",
+ displayArgs: "('foo', 'bar')",
+ isMeasurement: false,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [],
+ targets: [
+ { type: RegisterType.Qubit, qId: 0 },
+ { type: RegisterType.Qubit, qId: 1 },
+ ]
+ };
+ let metadata: Metadata = {
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [startY, startY + registerHeight],
+ label: "U",
+ displayArgs: "('foo', 'bar')",
+ width: 77
+ };
+ expect(_opToMetadata(op, registers)).toEqual(metadata);
+
+ // Test long argument
+ op = {
+ gate: "U",
+ displayArgs: "(0.25, 1.0, 'foobar', (3.14, 6.67))",
+ isMeasurement: false,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [],
+ targets: [
+ { type: RegisterType.Qubit, qId: 0 },
+ { type: RegisterType.Qubit, qId: 1 },
+ ]
+ };
+ metadata = {
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [startY, startY + registerHeight],
+ label: "U",
+ displayArgs: "(0.25, 1.0, 'foobar', (3.14, 6.67))",
+ width: 188
+ };
+ expect(_opToMetadata(op, registers)).toEqual(metadata);
+
+ // Test isControlled
+ op = {
+ gate: "U",
+ displayArgs: "('foo', 'bar')",
+ isMeasurement: false,
+ isControlled: true,
+ isAdjoint: false,
+ controls: [{ type: RegisterType.Qubit, qId: 1 }],
+ targets: [
+ { type: RegisterType.Qubit, qId: 0 },
+ { type: RegisterType.Qubit, qId: 2 },
+ ]
+ };
+ metadata = {
+ type: GateType.ControlledUnitary,
+ x: 0,
+ controlsY: [startY + registerHeight],
+ targetsY: [startY, startY + registerHeight * 2],
+ label: "U",
+ displayArgs: "('foo', 'bar')",
+ width: 77
+ };
+ expect(_opToMetadata(op, registers)).toEqual(metadata);
+ });
+ test("classically isControlled gates", () => {
+ const op: Operation = {
+ gate: "X",
+ isMeasurement: false,
+ isControlled: true,
+ isAdjoint: false,
+ controls: [{ type: RegisterType.Classical, qId: 0, cId: 0 }],
+ targets: [
+ { type: RegisterType.Qubit, qId: 0 },
+ { type: RegisterType.Qubit, qId: 1 },
+ ],
+ children: [
+ [{
+ gate: "X",
+ isMeasurement: false,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [],
+ targets: [{ type: RegisterType.Qubit, qId: 0 }]
+ }],
+ [{
+ gate: "H",
+ isMeasurement: false,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [],
+ targets: [{ type: RegisterType.Qubit, qId: 1 }]
+ }]
+ ]
+ };
+ const registers: RegisterMap = {
+ 0: { type: RegisterType.Qubit, y: startY, children: [{ type: RegisterType.Classical, y: startY + classicalRegHeight }] },
+ 1: { type: RegisterType.Qubit, y: startY + classicalRegHeight * 2 },
+ };
+ const metadata: Metadata = {
+ type: GateType.ClassicalControlled,
+ x: 0,
+ controlsY: [startY + classicalRegHeight],
+ targetsY: [startY, startY + classicalRegHeight * 2],
+ label: '',
+ width: minGateWidth + controlBtnOffset + classicalBoxPadding * 2,
+ children: [
+ [{
+ type: GateType.Unitary,
+ x: startX + minGateWidth / 2,
+ controlsY: [],
+ targetsY: [startY],
+ label: 'X',
+ width: minGateWidth
+ }],
+ [{
+ type: GateType.Unitary,
+ x: startX + minGateWidth / 2,
+ controlsY: [],
+ targetsY: [startY + classicalRegHeight * 2],
+ label: 'H',
+ width: minGateWidth
+ }]
+ ]
+ };
+ expect(_opToMetadata(op, registers)).toEqual(metadata);
+ });
+ test("no render on null", () => {
+ const metadata: Metadata = {
+ type: GateType.Invalid,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ label: '',
+ width: minGateWidth
+ };
+ expect(_opToMetadata(null, [])).toEqual(metadata);
+ });
+ test("Invalid register", () => {
+ let op: Operation = {
+ gate: "X",
+ isMeasurement: false,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [],
+ targets: [{ type: RegisterType.Qubit, qId: 1 }]
+ };
+ const registers: RegisterMap = {
+ 0: { type: RegisterType.Qubit, y: startY },
+ };
+ expect(() => _opToMetadata(op, registers))
+ .toThrowError('ERROR: Qubit register with ID 1 not found.');
+
+ op = {
+ gate: "X",
+ isMeasurement: false,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [{ type: RegisterType.Classical, qId: 0, cId: 2 }],
+ targets: []
+ };
+ expect(() => _opToMetadata(op, registers))
+ .toThrowError('ERROR: No classical registers found for qubit ID 0.');
+ });
+ test("skipped registers", () => {
+ const op: Operation = {
+ gate: "X",
+ isMeasurement: false,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [],
+ targets: [{ type: RegisterType.Qubit, qId: 2 }]
+ };
+ const registers: RegisterMap = {
+ 0: { type: RegisterType.Qubit, y: startY },
+ 2: { type: RegisterType.Qubit, y: startY + registerHeight },
+ };
+ const metadata: Metadata = {
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [startY + registerHeight],
+ label: "X",
+ width: minGateWidth
+ };
+ expect(_opToMetadata(op, registers)).toEqual(metadata);
+ });
+});
+
+describe("Testing _getRegY", () => {
+ const registers: RegisterMap = {
+ 0: {
+ type: RegisterType.Qubit,
+ y: startY,
+ children: [{ type: RegisterType.Classical, y: startY + classicalRegHeight }]
+ }
+ };
+ test("quantum register", () => {
+ const reg: Register = { type: RegisterType.Qubit, qId: 0 };
+ expect(_getRegY(reg, registers)).toEqual(startY);
+ });
+ test("classical register", () => {
+ const reg: Register = { type: RegisterType.Classical, qId: 0, cId: 0 };
+ expect(_getRegY(reg, registers)).toEqual(startY + classicalRegHeight);
+ });
+ test("No children", () => {
+ const registers: RegisterMap = {
+ 0: { type: RegisterType.Qubit, y: startY }
+ };
+ const reg: Register = { type: RegisterType.Classical, qId: 0, cId: 0 };
+ expect(() => _getRegY(reg, registers)).toThrowError("ERROR: No classical registers found for qubit ID 0.");
+ });
+ test("Null cId", () => {
+ const reg: Register = { type: RegisterType.Classical, qId: 0 };
+ expect(() => _getRegY(reg, registers)).toThrowError("ERROR: No ID defined for classical register associated with qubit ID 0.");
+ });
+ test("Invalid cId", () => {
+ const reg: Register = { type: RegisterType.Classical, qId: 0, cId: 1 };
+ expect(() => _getRegY(reg, registers)).toThrowError("ERROR: Classical register ID 1 invalid for qubit ID 0 with 1 classical register(s).");
+ });
+ test("Invalid register type", () => {
+ const reg: Register = { type: 2, qId: 0, cId: 1 };
+ expect(() => _getRegY(reg, registers)).toThrowError("ERROR: Unknown register type 2.");
+ });
+});
+
+describe("Testing _addClass", () => {
+ test("No children", () => {
+ const cls: string = 'classname';
+ const metadata: Metadata = {
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ children: [[], []],
+ label: 'X',
+ width: minGateWidth,
+ };
+ const expected: Metadata = {
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ children: [[], []],
+ label: 'X',
+ width: minGateWidth,
+ htmlClass: 'classname',
+ };
+
+ _addClass(metadata, cls);
+ expect(metadata).toEqual(expected);
+ });
+ test("Undefined children", () => {
+ const cls: string = 'classname';
+ const metadata: Metadata = {
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ label: 'X',
+ width: minGateWidth,
+ };
+ const expected: Metadata = {
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ label: 'X',
+ width: minGateWidth,
+ htmlClass: 'classname',
+ };
+ _addClass(metadata, cls);
+ expect(metadata).toEqual(expected);
+ });
+ test("depth-1 children", () => {
+ const cls: string = 'classname';
+ const metadata: Metadata = {
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ children: [[{
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ label: 'X',
+ width: minGateWidth,
+ }], [{
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ label: 'X',
+ width: minGateWidth,
+ }]],
+ label: 'X',
+ width: minGateWidth,
+ };
+ const expected: Metadata = {
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ children: [[{
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ label: 'X',
+ width: minGateWidth,
+ htmlClass: 'classname',
+ }], [{
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ label: 'X',
+ width: minGateWidth,
+ htmlClass: 'classname',
+ }]],
+ label: 'X',
+ width: minGateWidth,
+ htmlClass: 'classname',
+ };
+
+ _addClass(metadata, cls);
+ expect(metadata).toEqual(expected);
+ });
+ test("depth-2 children", () => {
+ const cls: string = 'classname';
+ const metadata: Metadata = {
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ children: [[{
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ children: [[{
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ label: 'X',
+ width: minGateWidth,
+ }], [{
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ label: 'X',
+ width: minGateWidth,
+ }]],
+ label: 'X',
+ width: minGateWidth,
+ }], [{
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ label: 'X',
+ width: minGateWidth,
+ }]],
+ label: 'X',
+ width: minGateWidth,
+ };
+ const expected: Metadata = {
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ children: [[{
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ children: [[{
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ label: 'X',
+ width: minGateWidth,
+ htmlClass: 'classname',
+ }], [{
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ label: 'X',
+ width: minGateWidth,
+ htmlClass: 'classname',
+ }]],
+ label: 'X',
+ width: minGateWidth,
+ htmlClass: 'classname',
+ }], [{
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ label: 'X',
+ width: minGateWidth,
+ htmlClass: 'classname',
+ }]],
+ label: 'X',
+ width: minGateWidth,
+ htmlClass: 'classname',
+ };
+
+ _addClass(metadata, cls);
+ expect(metadata).toEqual(expected);
+ });
+});
+
+describe("Testing _offsetChildrenX", () => {
+ const offset: number = 50;
+ test("no grandchildren", () => {
+ const children: Metadata[][] = [[{
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ width: minGateWidth,
+ label: 'X',
+ }]];
+ const expected: Metadata[][] = [[{
+ type: GateType.Unitary,
+ x: 50,
+ controlsY: [],
+ targetsY: [],
+ width: minGateWidth,
+ label: 'X',
+ }]];
+ _offsetChildrenX(children, offset);
+ expect(children).toEqual(expected);
+ });
+ test("has grandchildren", () => {
+ const children: Metadata[][] = [[{
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ width: minGateWidth,
+ label: 'X',
+ children: [[{
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ width: minGateWidth,
+ label: 'X',
+ }], []]
+ }]];
+ const expected: Metadata[][] = [[{
+ type: GateType.Unitary,
+ x: 50,
+ controlsY: [],
+ targetsY: [],
+ width: minGateWidth,
+ label: 'X',
+ children: [[{
+ type: GateType.Unitary,
+ x: 50,
+ controlsY: [],
+ targetsY: [],
+ width: minGateWidth,
+ label: 'X',
+ }], []]
+ }]];
+ _offsetChildrenX(children, offset);
+ expect(children).toEqual(expected);
+ });
+ test("undefined child", () => {
+ expect(() => _offsetChildrenX(undefined, offset)).not.toThrow();
+ });
+});
+
+describe("Testing _fillMetadataX", () => {
+ test("Non-classically-isControlled gate", () => {
+ const columnWidths: number[] = Array(1).fill(minGateWidth);
+ const expectedEndX = startX + minGateWidth + gatePadding * 2;
+ const opsMetadata: Metadata[][] = [
+ [{
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ label: 'X',
+ width: minGateWidth,
+ }]
+ ];
+ const expected: Metadata[][] = [
+ [{
+ type: GateType.Unitary,
+ x: startX + minGateWidth / 2,
+ controlsY: [],
+ targetsY: [],
+ label: 'X',
+ width: minGateWidth,
+ }]
+ ];
+ const endX: number = _fillMetadataX(opsMetadata, columnWidths);
+ expect(opsMetadata).toEqual(expected);
+ expect(endX).toEqual(expectedEndX);
+ });
+ test("classically-isControlled gate with no children", () => {
+ const columnWidths: number[] = Array(1).fill(minGateWidth);
+ const expectedEndX = startX + minGateWidth + gatePadding * 2;
+ const opsMetadata: Metadata[][] = [
+ [{
+ type: GateType.ClassicalControlled,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ label: 'X',
+ width: minGateWidth,
+ }]
+ ];
+ const expected: Metadata[][] = [
+ [{
+ type: GateType.ClassicalControlled,
+ x: startX,
+ controlsY: [],
+ targetsY: [],
+ label: 'X',
+ width: minGateWidth,
+ }]
+ ];
+ const endX: number = _fillMetadataX(opsMetadata, columnWidths);
+ expect(opsMetadata).toEqual(expected);
+ expect(endX).toEqual(expectedEndX);
+ });
+ test("depth-1 children", () => {
+ const columnWidths: number[] = Array(1).fill(minGateWidth + gatePadding * 2);
+ const expectedEndX = startX + minGateWidth + gatePadding * 4;
+ const opsMetadata: Metadata[][] = [[{
+ type: GateType.ClassicalControlled,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ children: [[{
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ label: 'X',
+ width: minGateWidth,
+ }], [{
+ type: GateType.Unitary,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ label: 'X',
+ width: minGateWidth,
+ }]],
+ label: 'X',
+ width: minGateWidth + controlBtnOffset + classicalBoxPadding * 2,
+ }]];
+ const expected: Metadata[][] = [[{
+ type: GateType.ClassicalControlled,
+ x: startX,
+ controlsY: [],
+ targetsY: [],
+ children: [[{
+ type: GateType.Unitary,
+ x: controlBtnOffset + classicalBoxPadding,
+ controlsY: [],
+ targetsY: [],
+ label: 'X',
+ width: minGateWidth,
+ }], [{
+ type: GateType.Unitary,
+ x: controlBtnOffset + classicalBoxPadding,
+ controlsY: [],
+ targetsY: [],
+ label: 'X',
+ width: minGateWidth,
+ }]],
+ label: 'X',
+ width: minGateWidth + controlBtnOffset + classicalBoxPadding * 2,
+ }]];
+
+ const endX: number = _fillMetadataX(opsMetadata, columnWidths);
+ expect(opsMetadata).toEqual(expected);
+ expect(endX).toEqual(expectedEndX);
+ });
+});
+
+describe("Testing processOperations", () => {
+ test("single qubit gates", () => {
+ const rxWidth: number = 52;
+ const operations: Operation[] = [
+ {
+ gate: "H",
+ isMeasurement: false,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [],
+ targets: [{ type: RegisterType.Qubit, qId: 0 }]
+ },
+ {
+ gate: "H",
+ isMeasurement: false,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [],
+ targets: [{ type: RegisterType.Qubit, qId: 0 }]
+ },
+ {
+ gate: "H",
+ isMeasurement: false,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [],
+ targets: [{ type: RegisterType.Qubit, qId: 1 }]
+ },
+ {
+ gate: "RX",
+ displayArgs: "(0.25)",
+ isMeasurement: false,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [],
+ targets: [{ type: RegisterType.Qubit, qId: 1 }]
+ },
+ ];
+ const registers: RegisterMap = {
+ 0: { type: RegisterType.Qubit, y: startY },
+ 1: { type: RegisterType.Qubit, y: startY + registerHeight },
+ };
+ const expectedOps: Metadata[] = [
+ {
+ type: GateType.Unitary,
+ x: startX + minGateWidth / 2,
+ controlsY: [],
+ targetsY: [startY],
+ label: "H",
+ width: minGateWidth,
+ },
+ {
+ type: GateType.Unitary,
+ x: startX + (minGateWidth + gatePadding * 2) + rxWidth / 2,
+ controlsY: [],
+ targetsY: [startY],
+ label: "H",
+ width: minGateWidth,
+ },
+ {
+ type: GateType.Unitary,
+ x: startX + minGateWidth / 2,
+ controlsY: [],
+ targetsY: [startY + registerHeight],
+ label: "H",
+ width: minGateWidth,
+ },
+ {
+ type: GateType.Unitary,
+ x: startX + (minGateWidth + gatePadding * 2) + rxWidth / 2,
+ controlsY: [],
+ targetsY: [startY + registerHeight],
+ label: "RX",
+ displayArgs: "(0.25)",
+ width: rxWidth,
+ }
+ ];
+ const expectedWidth: number = startX + minGateWidth + rxWidth + gatePadding * 4;
+ const { metadataList, svgWidth } = processOperations(operations, registers);
+ expect(metadataList).toEqual(expectedOps);
+ expect(svgWidth).toEqual(expectedWidth);
+ });
+ test("single wide qubit gates", () => {
+ const expectedCustomWidth: number = 67;
+ const operations: Operation[] = [
+ {
+ gate: "H",
+ isMeasurement: false,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [],
+ targets: [{ type: RegisterType.Qubit, qId: 0 }]
+ },
+ {
+ gate: "FooBar",
+ isMeasurement: false,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [],
+ targets: [{ type: RegisterType.Qubit, qId: 0 }]
+ },
+ {
+ gate: "H",
+ isMeasurement: false,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [],
+ targets: [{ type: RegisterType.Qubit, qId: 1 }]
+ },
+ ];
+ const registers: RegisterMap = {
+ 0: { type: RegisterType.Qubit, y: startY },
+ 1: { type: RegisterType.Qubit, y: startY + registerHeight },
+ };
+ const expectedOps: Metadata[] = [
+ {
+ type: GateType.Unitary,
+ x: startX + minGateWidth / 2,
+ controlsY: [],
+ targetsY: [startY],
+ label: "H",
+ width: minGateWidth,
+ },
+ {
+ type: GateType.Unitary,
+ x: startX + (minGateWidth + gatePadding * 2) + expectedCustomWidth / 2,
+ controlsY: [],
+ targetsY: [startY],
+ label: "FooBar",
+ width: expectedCustomWidth,
+ },
+ {
+ type: GateType.Unitary,
+ x: startX + minGateWidth / 2,
+ controlsY: [],
+ targetsY: [startY + registerHeight],
+ label: "H",
+ width: minGateWidth,
+ }
+ ];
+ const expectedWidth: number = startX + minGateWidth + expectedCustomWidth + gatePadding * 4;
+ const { metadataList, svgWidth } = processOperations(operations, registers);
+ expect(metadataList).toEqual(expectedOps);
+ expect(svgWidth).toEqual(expectedWidth);
+ });
+ test("single and multi qubit gates", () => {
+ const operations: Operation[] = [
+ {
+ gate: "H",
+ isMeasurement: false,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [],
+ targets: [{ type: RegisterType.Qubit, qId: 0 }]
+ },
+ {
+ gate: "X",
+ isMeasurement: false,
+ isControlled: true,
+ isAdjoint: false,
+ controls: [{ type: RegisterType.Qubit, qId: 1 }],
+ targets: [{ type: RegisterType.Qubit, qId: 0 }]
+ },
+ {
+ gate: "H",
+ isMeasurement: false,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [],
+ targets: [{ type: RegisterType.Qubit, qId: 1 }]
+ },
+ ];
+ const registers: RegisterMap = {
+ 0: { type: RegisterType.Qubit, y: startY },
+ 1: { type: RegisterType.Qubit, y: startY + registerHeight },
+ };
+ const expectedOps: Metadata[] = [
+ {
+ type: GateType.Unitary,
+ x: startX + minGateWidth / 2,
+ controlsY: [],
+ targetsY: [startY],
+ label: "H",
+ width: minGateWidth,
+ },
+ {
+ type: GateType.Cnot,
+ x: startX + (minGateWidth + gatePadding * 2) + minGateWidth / 2,
+ controlsY: [startY + registerHeight],
+ targetsY: [startY],
+ label: "X",
+ width: minGateWidth,
+ },
+ {
+ type: GateType.Unitary,
+ x: startX + (minGateWidth + gatePadding * 2) * 2 + minGateWidth / 2,
+ controlsY: [],
+ targetsY: [startY + registerHeight],
+ label: "H",
+ width: minGateWidth,
+ }
+ ];
+ const expectedWidth: number = startX + (minGateWidth + gatePadding * 2) * 3;
+ const { metadataList, svgWidth } = processOperations(operations, registers);
+ expect(metadataList).toEqual(expectedOps);
+ expect(svgWidth).toEqual(expectedWidth);
+ });
+ test("measure gates", () => {
+ const operations: Operation[] = [
+ {
+ gate: "H",
+ isMeasurement: false,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [],
+ targets: [{ type: RegisterType.Qubit, qId: 0 }]
+ },
+ {
+ gate: "M",
+ isMeasurement: true,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [{ type: RegisterType.Qubit, qId: 0 }],
+ targets: [{ type: RegisterType.Classical, qId: 0, cId: 0 }]
+ },
+ {
+ gate: "H",
+ isMeasurement: false,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [],
+ targets: [{ type: RegisterType.Qubit, qId: 1 }]
+ },
+ {
+ gate: "M",
+ isMeasurement: true,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [{ type: RegisterType.Qubit, qId: 0 }],
+ targets: [{ type: RegisterType.Classical, qId: 0, cId: 1 }]
+ },
+ ];
+ const registers: RegisterMap = {
+ 0: {
+ type: RegisterType.Qubit,
+ y: startY,
+ children: [
+ { type: RegisterType.Classical, y: startY + classicalRegHeight },
+ { type: RegisterType.Classical, y: startY + classicalRegHeight * 2 },
+ ]
+ },
+ 1: { type: RegisterType.Qubit, y: startY + classicalRegHeight * 3 },
+ };
+ const expectedOps: Metadata[] = [
+ {
+ type: GateType.Unitary,
+ x: startX + minGateWidth / 2,
+ controlsY: [],
+ targetsY: [startY],
+ label: "H",
+ width: minGateWidth,
+ },
+ {
+ type: GateType.Measure,
+ x: startX + minGateWidth + gatePadding * 2 + minGateWidth / 2,
+ controlsY: [startY],
+ targetsY: [startY + classicalRegHeight],
+ label: "",
+ width: minGateWidth,
+ },
+ {
+ type: GateType.Measure,
+ x: startX + (minGateWidth + gatePadding * 2) * 2 + minGateWidth / 2,
+ controlsY: [startY],
+ targetsY: [startY + classicalRegHeight * 2],
+ label: "",
+ width: minGateWidth,
+ },
+ {
+ type: GateType.Unitary,
+ x: startX + minGateWidth / 2,
+ controlsY: [],
+ targetsY: [startY + classicalRegHeight * 3],
+ label: "H",
+ width: minGateWidth,
+ },
+ ];
+ const expectedWidth: number = startX + (minGateWidth + gatePadding * 2) * 3;
+ const { metadataList, svgWidth } = processOperations(operations, registers);
+ expect(metadataList).toEqual(expectedOps);
+ expect(svgWidth).toEqual(expectedWidth);
+ });
+ test("skipped registers", () => {
+ const operations: Operation[] = [
+ {
+ gate: "H",
+ isMeasurement: false,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [],
+ targets: [{ type: RegisterType.Qubit, qId: 0 }]
+ },
+ {
+ gate: "H",
+ isMeasurement: false,
+ isControlled: false,
+ isAdjoint: false,
+ controls: [],
+ targets: [{ type: RegisterType.Qubit, qId: 2 }]
+ },
+ ];
+ const registers: RegisterMap = {
+ 0: {
+ type: RegisterType.Qubit,
+ y: startY,
+ children: [
+ { type: RegisterType.Classical, y: startY + classicalRegHeight },
+ { type: RegisterType.Classical, y: startY + classicalRegHeight * 2 },
+ ]
+ },
+ 2: { type: RegisterType.Qubit, y: startY + classicalRegHeight * 3 },
+ };
+ const expectedOps: Metadata[] = [
+ {
+ type: GateType.Unitary,
+ x: startX + minGateWidth / 2,
+ controlsY: [],
+ targetsY: [startY],
+ label: "H",
+ width: minGateWidth,
+ },
+ {
+ type: GateType.Unitary,
+ x: startX + minGateWidth / 2,
+ controlsY: [],
+ targetsY: [startY + classicalRegHeight * 3],
+ label: "H",
+ width: minGateWidth,
+ },
+ ];
+ const expectedWidth: number = startX + minGateWidth + gatePadding * 2;
+ const { metadataList, svgWidth } = processOperations(operations, registers);
+ expect(metadataList).toEqual(expectedOps);
+ expect(svgWidth).toEqual(expectedWidth);
+ });
+});
diff --git a/src/Kernel/client/__tests__/ExecutionPathVisualizerTests/registerFormatter.test.ts b/src/Kernel/client/__tests__/ExecutionPathVisualizerTests/registerFormatter.test.ts
new file mode 100644
index 0000000000..ffbaabbe57
--- /dev/null
+++ b/src/Kernel/client/__tests__/ExecutionPathVisualizerTests/registerFormatter.test.ts
@@ -0,0 +1,178 @@
+import {
+ formatRegisters,
+ _classicalRegister,
+ _qubitRegister,
+} from "../../ExecutionPathVisualizer/formatters/registerFormatter";
+import { RegisterMap, RegisterType } from "../../ExecutionPathVisualizer/register";
+import { Metadata } from "../../ExecutionPathVisualizer/metadata";
+import {
+ startY,
+ registerHeight,
+ classicalRegHeight,
+ GateType,
+ startX,
+ minGateWidth
+} from "../../ExecutionPathVisualizer/constants";
+
+describe("Testing _classicalRegister", () => {
+ test("register with normal width", () => {
+ expect(_classicalRegister(10, 10, 100, 20)).toMatchSnapshot();
+ expect(_classicalRegister(10, 10, 100, 20)).toMatchSnapshot();
+ expect(_classicalRegister(10, 10, 100, 20)).toMatchSnapshot();
+ });
+ test("register with small width", () => {
+ expect(_classicalRegister(10, 10, 5, 20)).toMatchSnapshot();
+ expect(_classicalRegister(10, 10, 5, 20)).toMatchSnapshot();
+ expect(_classicalRegister(10, 10, 5, 20)).toMatchSnapshot();
+ });
+ test("register with large width", () => {
+ expect(_classicalRegister(10, 10, 500, 20)).toMatchSnapshot();
+ expect(_classicalRegister(10, 10, 500, 20)).toMatchSnapshot();
+ expect(_classicalRegister(10, 10, 500, 20)).toMatchSnapshot();
+ });
+ test("register with label offset", () => {
+ expect(_classicalRegister(10, 10, 100, 20)).toMatchSnapshot();
+ expect(_classicalRegister(10, 10, 100, 20)).toMatchSnapshot();
+ expect(_classicalRegister(10, 10, 100, 20)).toMatchSnapshot();
+ });
+});
+
+describe("Testing _qubitRegister", () => {
+ test("register with normal width", () => {
+ expect(_qubitRegister(0, 100, 20)).toMatchSnapshot();
+ expect(_qubitRegister(1, 100, 20)).toMatchSnapshot();
+ expect(_qubitRegister(2, 100, 20)).toMatchSnapshot();
+ });
+ test("register with small width", () => {
+ expect(_qubitRegister(0, 5, 20)).toMatchSnapshot();
+ expect(_qubitRegister(1, 5, 20)).toMatchSnapshot();
+ expect(_qubitRegister(2, 5, 20)).toMatchSnapshot();
+ });
+ test("register with large width", () => {
+ expect(_qubitRegister(0, 500, 20)).toMatchSnapshot();
+ expect(_qubitRegister(1, 500, 20)).toMatchSnapshot();
+ expect(_qubitRegister(2, 500, 20)).toMatchSnapshot();
+ });
+ test("register with label offset", () => {
+ expect(_qubitRegister(0, 100, 20, 0)).toMatchSnapshot();
+ expect(_qubitRegister(1, 100, 20, 5)).toMatchSnapshot();
+ expect(_qubitRegister(2, 100, 20, 50)).toMatchSnapshot();
+ });
+});
+
+describe("Testing formatRegisters", () => {
+ test("1 quantum register", () => {
+ const registers: RegisterMap = { 0: { type: RegisterType.Qubit, y: startY } }
+ // Normal width
+ expect(formatRegisters(registers, [], startX + 100)).toMatchSnapshot();
+ // Small width
+ expect(formatRegisters(registers, [], startX + 5)).toMatchSnapshot();
+ // Large width
+ expect(formatRegisters(registers, [], startX + 500)).toMatchSnapshot();
+ });
+ test("Multiple quantum registers", () => {
+ const registers: RegisterMap = {
+ 0: { type: RegisterType.Qubit, y: startY },
+ 1: { type: RegisterType.Qubit, y: startY + registerHeight },
+ 2: { type: RegisterType.Qubit, y: startY + registerHeight * 2 },
+ 3: { type: RegisterType.Qubit, y: startY + registerHeight * 3 },
+ };
+ // Normal width
+ expect(formatRegisters(registers, [], startX + 100)).toMatchSnapshot();
+ // Small width
+ expect(formatRegisters(registers, [], startX + 5)).toMatchSnapshot();
+ // Large width
+ expect(formatRegisters(registers, [], startX + 500)).toMatchSnapshot();
+ });
+ test("Skipped quantum registers", () => {
+ const registers: RegisterMap = {
+ 0: { type: RegisterType.Qubit, y: startY },
+ 2: { type: RegisterType.Qubit, y: startY + registerHeight * 2 },
+ 3: { type: RegisterType.Qubit, y: startY + registerHeight * 3 },
+ };
+ // Normal width
+ expect(formatRegisters(registers, [], startX + 100)).toMatchSnapshot();
+ // Small width
+ expect(formatRegisters(registers, [], startX + 5)).toMatchSnapshot();
+ // Large width
+ expect(formatRegisters(registers, [], startX + 500)).toMatchSnapshot();
+ });
+ test("Quantum and classical registers", () => {
+ let registers: RegisterMap = {
+ 0: {
+ type: RegisterType.Qubit,
+ y: startY,
+ children: [{ type: RegisterType.Classical, y: startY + classicalRegHeight }]
+ },
+ 1: { type: RegisterType.Qubit, y: startY + classicalRegHeight * 2 },
+ 2: { type: RegisterType.Qubit, y: startY + registerHeight + classicalRegHeight * 2 },
+ };
+ let measureGates: Metadata[] = [
+ {
+ type: GateType.Measure,
+ x: startX,
+ controlsY: [startY],
+ targetsY: [startY + classicalRegHeight],
+ label: '',
+ width: minGateWidth
+ }
+ ];
+ // Normal width
+ expect(formatRegisters(registers, measureGates, startX + 100)).toMatchSnapshot();
+ // Small width
+ expect(formatRegisters(registers, measureGates, startX + 5)).toMatchSnapshot();
+ // Large width
+ expect(formatRegisters(registers, measureGates, startX + 500)).toMatchSnapshot();
+
+ registers = {
+ 0: { type: RegisterType.Qubit, y: startY },
+ 1: {
+ type: RegisterType.Qubit,
+ y: startY + registerHeight,
+ children: [
+ { type: RegisterType.Classical, y: startY + registerHeight + classicalRegHeight },
+ { type: RegisterType.Classical, y: startY + registerHeight + classicalRegHeight * 2 },
+ ]
+ },
+ 2: {
+ type: RegisterType.Qubit,
+ y: startY + registerHeight + classicalRegHeight * 3,
+ children: [
+ { type: RegisterType.Classical, y: startY + registerHeight + classicalRegHeight * 4 },
+ ]
+ },
+ };
+ measureGates = [
+ {
+ type: GateType.Measure,
+ x: startX,
+ controlsY: [startY],
+ targetsY: [startY + classicalRegHeight],
+ label: '',
+ width: minGateWidth
+ },
+ {
+ type: GateType.Measure,
+ x: startX,
+ controlsY: [startY],
+ targetsY: [startY + classicalRegHeight * 2],
+ label: '',
+ width: minGateWidth
+ },
+ {
+ type: GateType.Measure,
+ x: startX,
+ controlsY: [startY + classicalRegHeight * 3],
+ targetsY: [startY + classicalRegHeight * 4],
+ label: '',
+ width: minGateWidth
+ },
+ ];
+ // Normal width
+ expect(formatRegisters(registers, measureGates, startX + 100)).toMatchSnapshot();
+ // Small width
+ expect(formatRegisters(registers, measureGates, startX + 5)).toMatchSnapshot();
+ // Large width
+ expect(formatRegisters(registers, measureGates, startX + 500)).toMatchSnapshot();
+ });
+});
diff --git a/src/Kernel/client/__tests__/ExecutionPathVisualizerTests/utils.test.ts b/src/Kernel/client/__tests__/ExecutionPathVisualizerTests/utils.test.ts
new file mode 100644
index 0000000000..6edea89911
--- /dev/null
+++ b/src/Kernel/client/__tests__/ExecutionPathVisualizerTests/utils.test.ts
@@ -0,0 +1,60 @@
+import { getGateWidth, _getStringWidth } from "../../ExecutionPathVisualizer/utils";
+import { Metadata } from "../../ExecutionPathVisualizer/metadata";
+import { GateType, minGateWidth, labelPadding } from "../../ExecutionPathVisualizer/constants";
+
+describe("Testing getGateWidth", () => {
+ const testOp: Metadata = {
+ type: GateType.Invalid,
+ x: 0,
+ controlsY: [],
+ targetsY: [],
+ label: '',
+ width: minGateWidth
+ };
+ test("measure gate", () =>
+ expect(getGateWidth(Object.assign({ type: GateType.Measure, label: '' })))
+ .toEqual(minGateWidth));
+ test("cnot gate", () =>
+ expect(getGateWidth(Object.assign({ type: GateType.Cnot, label: 'x' })))
+ .toEqual(minGateWidth));
+ test("swap gate", () =>
+ expect(getGateWidth(Object.assign({ type: GateType.Swap, label: '' })))
+ .toEqual(minGateWidth));
+ test("single unitary gate", () =>
+ expect(getGateWidth(Object.assign({ type: GateType.Unitary, label: 'x' })))
+ .toEqual(minGateWidth));
+ test("multi unitary gate", () =>
+ expect(getGateWidth(Object.assign({ type: GateType.Unitary, label: 'zz' })))
+ .toEqual(minGateWidth));
+ test("unitary gate with arguments", () =>
+ expect(getGateWidth(Object.assign({ type: GateType.Unitary, displayArgs: '(0.25)', label: 'RX' })))
+ .toEqual(52));
+ test("invalid", () =>
+ expect(getGateWidth(Object.assign({ type: GateType.Invalid, label: '' })))
+ .toEqual(minGateWidth));
+ test("unitary with long name", () =>
+ expect(getGateWidth(Object.assign({ type: GateType.Unitary, label: 'FOOBAR' })))
+ .toBeCloseTo(59 + labelPadding * 2));
+ test("classically controlled gate", () => {
+ expect(getGateWidth(Object.assign({ type: GateType.ClassicalControlled, label: '', width: 500 })))
+ .toEqual(500);
+ });
+});
+
+describe("Testing _getStringWidth", () => {
+ test("correctly scaled width with font size", () => {
+ const fullSize: number = 423;
+ expect(_getStringWidth("FOOBAR", 14)).toEqual(59);
+ expect(_getStringWidth("FOOBAR", 20)).toEqual(84);
+ expect(_getStringWidth("FOOBAR", 5)).toEqual(21);
+ expect(_getStringWidth("FOOBAR", 100)).toEqual(423);
+ expect(_getStringWidth("FOOBAR", 200)).toEqual(844);
+ });
+
+ test("varying size strings", () => {
+ expect(_getStringWidth("H", 14)).toBeGreaterThanOrEqual(9);
+ expect(_getStringWidth("H", 14)).toBeLessThanOrEqual(10);
+ expect(_getStringWidth("GateWithASuperLongName", 14)).toBeGreaterThanOrEqual(174);
+ expect(_getStringWidth("GateWithASuperLongName", 14)).toBeLessThanOrEqual(176);
+ });
+});
diff --git a/src/Kernel/client/kernel.ts b/src/Kernel/client/kernel.ts
index 7590ddc03b..2bca79ba35 100644
--- a/src/Kernel/client/kernel.ts
+++ b/src/Kernel/client/kernel.ts
@@ -5,9 +5,10 @@
///
import { IPython } from "./ipython";
-declare var IPython : IPython;
+declare var IPython: IPython;
import { Telemetry, ClientInfo } from "./telemetry.js";
+import renderExecutionPath from "./ExecutionPathVisualizer/pathVisualizer.js";
function defineQSharpMode() {
console.log("Loading IQ# kernel-specific extension...");
@@ -66,7 +67,7 @@ function defineQSharpMode() {
{
// built-in magic commands
token: "builtin",
- regex: String.raw`(%(config|estimate|lsmagic|package|performance|simulate|toffoli|version|who|workspace))\b`,
+ regex: String.raw`(%(config|estimate|lsmagic|lsopen|package|performance|simulate|toffoli|trace|version|who|workspace))\b`,
beginWord: true,
},
{
@@ -116,14 +117,15 @@ function defineQSharpMode() {
}
class Kernel {
- hostingEnvironment : string | undefined;
- iqsharpVersion : string | undefined;
- telemetryOptOut? : boolean | null;
+ hostingEnvironment: string | undefined;
+ iqsharpVersion: string | undefined;
+ telemetryOptOut?: boolean | null;
constructor() {
IPython.notebook.kernel.events.on("kernel_ready.Kernel", args => {
this.requestEcho();
this.requestClientInfo();
+ this.initExecutionPathVisualizer();
});
}
@@ -147,7 +149,7 @@ class Kernel {
// are replies to other messages.
IPython.notebook.kernel.send_shell_message(
"iqsharp_echo_request",
- {value: value},
+ { value: value },
{
shell: {
reply: (message) => {
@@ -224,6 +226,16 @@ class Kernel {
});
Telemetry.initAsync();
}
+
+ initExecutionPathVisualizer() {
+ IPython.notebook.kernel.register_iopub_handler(
+ "render_execution_path",
+ message => {
+ const { executionPath, id } = message.content;
+ renderExecutionPath(executionPath, id);
+ }
+ );
+ }
}
export function onload() {
@@ -231,4 +243,3 @@ export function onload() {
let kernel = new Kernel();
console.log("Loaded IQ# kernel-specific extension!");
}
-
diff --git a/src/Kernel/package-lock.json b/src/Kernel/package-lock.json
index ba38a198ed..fc9d6f3e62 100644
--- a/src/Kernel/package-lock.json
+++ b/src/Kernel/package-lock.json
@@ -2,11 +2,6139 @@
"requires": true,
"lockfileVersion": 1,
"dependencies": {
+ "@babel/code-frame": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.10.4.tgz",
+ "integrity": "sha512-vG6SvB6oYEhvgisZNFRmRCUkLz11c7rp+tbNTynGqc6mS1d5ATd/sGyV6W0KZZnXRKMTzZDRgQT3Ou9jhpAfUg==",
+ "dev": true,
+ "requires": {
+ "@babel/highlight": "^7.10.4"
+ }
+ },
+ "@babel/core": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.10.4.tgz",
+ "integrity": "sha512-3A0tS0HWpy4XujGc7QtOIHTeNwUgWaZc/WuS5YQrfhU67jnVmsD6OGPc1AKHH0LJHQICGncy3+YUjIhVlfDdcA==",
+ "dev": true,
+ "requires": {
+ "@babel/code-frame": "^7.10.4",
+ "@babel/generator": "^7.10.4",
+ "@babel/helper-module-transforms": "^7.10.4",
+ "@babel/helpers": "^7.10.4",
+ "@babel/parser": "^7.10.4",
+ "@babel/template": "^7.10.4",
+ "@babel/traverse": "^7.10.4",
+ "@babel/types": "^7.10.4",
+ "convert-source-map": "^1.7.0",
+ "debug": "^4.1.0",
+ "gensync": "^1.0.0-beta.1",
+ "json5": "^2.1.2",
+ "lodash": "^4.17.13",
+ "resolve": "^1.3.2",
+ "semver": "^5.4.1",
+ "source-map": "^0.5.0"
+ },
+ "dependencies": {
+ "debug": {
+ "version": "4.1.1",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz",
+ "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==",
+ "dev": true,
+ "requires": {
+ "ms": "^2.1.1"
+ }
+ },
+ "source-map": {
+ "version": "0.5.7",
+ "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz",
+ "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=",
+ "dev": true
+ }
+ }
+ },
+ "@babel/generator": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.10.4.tgz",
+ "integrity": "sha512-toLIHUIAgcQygFZRAQcsLQV3CBuX6yOIru1kJk/qqqvcRmZrYe6WavZTSG+bB8MxhnL9YPf+pKQfuiP161q7ng==",
+ "dev": true,
+ "requires": {
+ "@babel/types": "^7.10.4",
+ "jsesc": "^2.5.1",
+ "lodash": "^4.17.13",
+ "source-map": "^0.5.0"
+ },
+ "dependencies": {
+ "source-map": {
+ "version": "0.5.7",
+ "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz",
+ "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=",
+ "dev": true
+ }
+ }
+ },
+ "@babel/helper-function-name": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.10.4.tgz",
+ "integrity": "sha512-YdaSyz1n8gY44EmN7x44zBn9zQ1Ry2Y+3GTA+3vH6Mizke1Vw0aWDM66FOYEPw8//qKkmqOckrGgTYa+6sceqQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-get-function-arity": "^7.10.4",
+ "@babel/template": "^7.10.4",
+ "@babel/types": "^7.10.4"
+ }
+ },
+ "@babel/helper-get-function-arity": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.10.4.tgz",
+ "integrity": "sha512-EkN3YDB+SRDgiIUnNgcmiD361ti+AVbL3f3Henf6dqqUyr5dMsorno0lJWJuLhDhkI5sYEpgj6y9kB8AOU1I2A==",
+ "dev": true,
+ "requires": {
+ "@babel/types": "^7.10.4"
+ }
+ },
+ "@babel/helper-member-expression-to-functions": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.10.4.tgz",
+ "integrity": "sha512-m5j85pK/KZhuSdM/8cHUABQTAslV47OjfIB9Cc7P+PvlAoBzdb79BGNfw8RhT5Mq3p+xGd0ZfAKixbrUZx0C7A==",
+ "dev": true,
+ "requires": {
+ "@babel/types": "^7.10.4"
+ }
+ },
+ "@babel/helper-module-imports": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.10.4.tgz",
+ "integrity": "sha512-nEQJHqYavI217oD9+s5MUBzk6x1IlvoS9WTPfgG43CbMEeStE0v+r+TucWdx8KFGowPGvyOkDT9+7DHedIDnVw==",
+ "dev": true,
+ "requires": {
+ "@babel/types": "^7.10.4"
+ }
+ },
+ "@babel/helper-module-transforms": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.10.4.tgz",
+ "integrity": "sha512-Er2FQX0oa3nV7eM1o0tNCTx7izmQtwAQsIiaLRWtavAAEcskb0XJ5OjJbVrYXWOTr8om921Scabn4/tzlx7j1Q==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-module-imports": "^7.10.4",
+ "@babel/helper-replace-supers": "^7.10.4",
+ "@babel/helper-simple-access": "^7.10.4",
+ "@babel/helper-split-export-declaration": "^7.10.4",
+ "@babel/template": "^7.10.4",
+ "@babel/types": "^7.10.4",
+ "lodash": "^4.17.13"
+ }
+ },
+ "@babel/helper-optimise-call-expression": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.10.4.tgz",
+ "integrity": "sha512-n3UGKY4VXwXThEiKrgRAoVPBMqeoPgHVqiHZOanAJCG9nQUL2pLRQirUzl0ioKclHGpGqRgIOkgcIJaIWLpygg==",
+ "dev": true,
+ "requires": {
+ "@babel/types": "^7.10.4"
+ }
+ },
+ "@babel/helper-plugin-utils": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.10.4.tgz",
+ "integrity": "sha512-O4KCvQA6lLiMU9l2eawBPMf1xPP8xPfB3iEQw150hOVTqj/rfXz0ThTb4HEzqQfs2Bmo5Ay8BzxfzVtBrr9dVg==",
+ "dev": true
+ },
+ "@babel/helper-replace-supers": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.10.4.tgz",
+ "integrity": "sha512-sPxZfFXocEymYTdVK1UNmFPBN+Hv5mJkLPsYWwGBxZAxaWfFu+xqp7b6qWD0yjNuNL2VKc6L5M18tOXUP7NU0A==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-member-expression-to-functions": "^7.10.4",
+ "@babel/helper-optimise-call-expression": "^7.10.4",
+ "@babel/traverse": "^7.10.4",
+ "@babel/types": "^7.10.4"
+ }
+ },
+ "@babel/helper-simple-access": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.10.4.tgz",
+ "integrity": "sha512-0fMy72ej/VEvF8ULmX6yb5MtHG4uH4Dbd6I/aHDb/JVg0bbivwt9Wg+h3uMvX+QSFtwr5MeItvazbrc4jtRAXw==",
+ "dev": true,
+ "requires": {
+ "@babel/template": "^7.10.4",
+ "@babel/types": "^7.10.4"
+ }
+ },
+ "@babel/helper-split-export-declaration": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.10.4.tgz",
+ "integrity": "sha512-pySBTeoUff56fL5CBU2hWm9TesA4r/rOkI9DyJLvvgz09MB9YtfIYe3iBriVaYNaPe+Alua0vBIOVOLs2buWhg==",
+ "dev": true,
+ "requires": {
+ "@babel/types": "^7.10.4"
+ }
+ },
+ "@babel/helper-validator-identifier": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.10.4.tgz",
+ "integrity": "sha512-3U9y+43hz7ZM+rzG24Qe2mufW5KhvFg/NhnNph+i9mgCtdTCtMJuI1TMkrIUiK7Ix4PYlRF9I5dhqaLYA/ADXw==",
+ "dev": true
+ },
+ "@babel/helpers": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.10.4.tgz",
+ "integrity": "sha512-L2gX/XeUONeEbI78dXSrJzGdz4GQ+ZTA/aazfUsFaWjSe95kiCuOZ5HsXvkiw3iwF+mFHSRUfJU8t6YavocdXA==",
+ "dev": true,
+ "requires": {
+ "@babel/template": "^7.10.4",
+ "@babel/traverse": "^7.10.4",
+ "@babel/types": "^7.10.4"
+ }
+ },
+ "@babel/highlight": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.10.4.tgz",
+ "integrity": "sha512-i6rgnR/YgPEQzZZnbTHHuZdlE8qyoBNalD6F+q4vAFlcMEcqmkoG+mPqJYJCo63qPf74+Y1UZsl3l6f7/RIkmA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-validator-identifier": "^7.10.4",
+ "chalk": "^2.0.0",
+ "js-tokens": "^4.0.0"
+ },
+ "dependencies": {
+ "ansi-styles": {
+ "version": "3.2.1",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz",
+ "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==",
+ "dev": true,
+ "requires": {
+ "color-convert": "^1.9.0"
+ }
+ },
+ "chalk": {
+ "version": "2.4.2",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz",
+ "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^3.2.1",
+ "escape-string-regexp": "^1.0.5",
+ "supports-color": "^5.3.0"
+ }
+ },
+ "color-convert": {
+ "version": "1.9.3",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz",
+ "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==",
+ "dev": true,
+ "requires": {
+ "color-name": "1.1.3"
+ }
+ },
+ "color-name": {
+ "version": "1.1.3",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz",
+ "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=",
+ "dev": true
+ },
+ "has-flag": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz",
+ "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=",
+ "dev": true
+ },
+ "supports-color": {
+ "version": "5.5.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz",
+ "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==",
+ "dev": true,
+ "requires": {
+ "has-flag": "^3.0.0"
+ }
+ }
+ }
+ },
+ "@babel/parser": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.10.4.tgz",
+ "integrity": "sha512-8jHII4hf+YVDsskTF6WuMB3X4Eh+PsUkC2ljq22so5rHvH+T8BzyL94VOdyFLNR8tBSVXOTbNHOKpR4TfRxVtA==",
+ "dev": true
+ },
+ "@babel/plugin-syntax-async-generators": {
+ "version": "7.8.4",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz",
+ "integrity": "sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ }
+ },
+ "@babel/plugin-syntax-bigint": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-bigint/-/plugin-syntax-bigint-7.8.3.tgz",
+ "integrity": "sha512-wnTnFlG+YxQm3vDxpGE57Pj0srRU4sHE/mDkt1qv2YJJSeUAec2ma4WLUnUPeKjyrfntVwe/N6dCXpU+zL3Npg==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ }
+ },
+ "@babel/plugin-syntax-class-properties": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.10.4.tgz",
+ "integrity": "sha512-GCSBF7iUle6rNugfURwNmCGG3Z/2+opxAMLs1nND4bhEG5PuxTIggDBoeYYSujAlLtsupzOHYJQgPS3pivwXIA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.10.4"
+ }
+ },
+ "@babel/plugin-syntax-import-meta": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-meta/-/plugin-syntax-import-meta-7.10.4.tgz",
+ "integrity": "sha512-Yqfm+XDx0+Prh3VSeEQCPU81yC+JWZ2pDPFSS4ZdpfZhp4MkFMaDC1UqseovEKwSUpnIL7+vK+Clp7bfh0iD7g==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.10.4"
+ }
+ },
+ "@babel/plugin-syntax-json-strings": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz",
+ "integrity": "sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ }
+ },
+ "@babel/plugin-syntax-logical-assignment-operators": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz",
+ "integrity": "sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.10.4"
+ }
+ },
+ "@babel/plugin-syntax-nullish-coalescing-operator": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz",
+ "integrity": "sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ }
+ },
+ "@babel/plugin-syntax-numeric-separator": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz",
+ "integrity": "sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.10.4"
+ }
+ },
+ "@babel/plugin-syntax-object-rest-spread": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz",
+ "integrity": "sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ }
+ },
+ "@babel/plugin-syntax-optional-catch-binding": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz",
+ "integrity": "sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ }
+ },
+ "@babel/plugin-syntax-optional-chaining": {
+ "version": "7.8.3",
+ "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz",
+ "integrity": "sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.8.0"
+ }
+ },
+ "@babel/template": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.10.4.tgz",
+ "integrity": "sha512-ZCjD27cGJFUB6nmCB1Enki3r+L5kJveX9pq1SvAUKoICy6CZ9yD8xO086YXdYhvNjBdnekm4ZnaP5yC8Cs/1tA==",
+ "dev": true,
+ "requires": {
+ "@babel/code-frame": "^7.10.4",
+ "@babel/parser": "^7.10.4",
+ "@babel/types": "^7.10.4"
+ }
+ },
+ "@babel/traverse": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.10.4.tgz",
+ "integrity": "sha512-aSy7p5THgSYm4YyxNGz6jZpXf+Ok40QF3aA2LyIONkDHpAcJzDUqlCKXv6peqYUs2gmic849C/t2HKw2a2K20Q==",
+ "dev": true,
+ "requires": {
+ "@babel/code-frame": "^7.10.4",
+ "@babel/generator": "^7.10.4",
+ "@babel/helper-function-name": "^7.10.4",
+ "@babel/helper-split-export-declaration": "^7.10.4",
+ "@babel/parser": "^7.10.4",
+ "@babel/types": "^7.10.4",
+ "debug": "^4.1.0",
+ "globals": "^11.1.0",
+ "lodash": "^4.17.13"
+ },
+ "dependencies": {
+ "debug": {
+ "version": "4.1.1",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz",
+ "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==",
+ "dev": true,
+ "requires": {
+ "ms": "^2.1.1"
+ }
+ }
+ }
+ },
+ "@babel/types": {
+ "version": "7.10.4",
+ "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.10.4.tgz",
+ "integrity": "sha512-UTCFOxC3FsFHb7lkRMVvgLzaRVamXuAs2Tz4wajva4WxtVY82eZeaUBtC2Zt95FU9TiznuC0Zk35tsim8jeVpg==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-validator-identifier": "^7.10.4",
+ "lodash": "^4.17.13",
+ "to-fast-properties": "^2.0.0"
+ }
+ },
+ "@bcoe/v8-coverage": {
+ "version": "0.2.3",
+ "resolved": "https://registry.npmjs.org/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz",
+ "integrity": "sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==",
+ "dev": true
+ },
+ "@cnakazawa/watch": {
+ "version": "1.0.4",
+ "resolved": "https://registry.npmjs.org/@cnakazawa/watch/-/watch-1.0.4.tgz",
+ "integrity": "sha512-v9kIhKwjeZThiWrLmj0y17CWoyddASLj9O2yvbZkbvw/N3rWOYy9zkV66ursAoVr0mV15bL8g0c4QZUE6cdDoQ==",
+ "dev": true,
+ "requires": {
+ "exec-sh": "^0.3.2",
+ "minimist": "^1.2.0"
+ }
+ },
+ "@istanbuljs/load-nyc-config": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz",
+ "integrity": "sha512-VjeHSlIzpv/NyD3N0YuHfXOPDIixcA1q2ZV98wsMqcYlPmv2n3Yb2lYP9XMElnaFVXg5A7YLTeLu6V84uQDjmQ==",
+ "dev": true,
+ "requires": {
+ "camelcase": "^5.3.1",
+ "find-up": "^4.1.0",
+ "get-package-type": "^0.1.0",
+ "js-yaml": "^3.13.1",
+ "resolve-from": "^5.0.0"
+ }
+ },
+ "@istanbuljs/schema": {
+ "version": "0.1.2",
+ "resolved": "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.2.tgz",
+ "integrity": "sha512-tsAQNx32a8CoFhjhijUIhI4kccIAgmGhy8LZMZgGfmXcpMbPRUqn5LWmgRttILi6yeGmBJd2xsPkFMs0PzgPCw==",
+ "dev": true
+ },
+ "@jest/console": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/console/-/console-26.1.0.tgz",
+ "integrity": "sha512-+0lpTHMd/8pJp+Nd4lyip+/Iyf2dZJvcCqrlkeZQoQid+JlThA4M9vxHtheyrQ99jJTMQam+es4BcvZ5W5cC3A==",
+ "dev": true,
+ "requires": {
+ "@jest/types": "^26.1.0",
+ "chalk": "^4.0.0",
+ "jest-message-util": "^26.1.0",
+ "jest-util": "^26.1.0",
+ "slash": "^3.0.0"
+ },
+ "dependencies": {
+ "@jest/types": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.1.0.tgz",
+ "integrity": "sha512-GXigDDsp6ZlNMhXQDeuy/iYCDsRIHJabWtDzvnn36+aqFfG14JmFV0e/iXxY4SP9vbXSiPNOWdehU5MeqrYHBQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0"
+ }
+ },
+ "chalk": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+ "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ }
+ }
+ },
+ "@jest/core": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/core/-/core-26.1.0.tgz",
+ "integrity": "sha512-zyizYmDJOOVke4OO/De//aiv8b07OwZzL2cfsvWF3q9YssfpcKfcnZAwDY8f+A76xXSMMYe8i/f/LPocLlByfw==",
+ "dev": true,
+ "requires": {
+ "@jest/console": "^26.1.0",
+ "@jest/reporters": "^26.1.0",
+ "@jest/test-result": "^26.1.0",
+ "@jest/transform": "^26.1.0",
+ "@jest/types": "^26.1.0",
+ "ansi-escapes": "^4.2.1",
+ "chalk": "^4.0.0",
+ "exit": "^0.1.2",
+ "graceful-fs": "^4.2.4",
+ "jest-changed-files": "^26.1.0",
+ "jest-config": "^26.1.0",
+ "jest-haste-map": "^26.1.0",
+ "jest-message-util": "^26.1.0",
+ "jest-regex-util": "^26.0.0",
+ "jest-resolve": "^26.1.0",
+ "jest-resolve-dependencies": "^26.1.0",
+ "jest-runner": "^26.1.0",
+ "jest-runtime": "^26.1.0",
+ "jest-snapshot": "^26.1.0",
+ "jest-util": "^26.1.0",
+ "jest-validate": "^26.1.0",
+ "jest-watcher": "^26.1.0",
+ "micromatch": "^4.0.2",
+ "p-each-series": "^2.1.0",
+ "rimraf": "^3.0.0",
+ "slash": "^3.0.0",
+ "strip-ansi": "^6.0.0"
+ },
+ "dependencies": {
+ "@jest/types": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.1.0.tgz",
+ "integrity": "sha512-GXigDDsp6ZlNMhXQDeuy/iYCDsRIHJabWtDzvnn36+aqFfG14JmFV0e/iXxY4SP9vbXSiPNOWdehU5MeqrYHBQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0"
+ }
+ },
+ "chalk": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+ "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ },
+ "rimraf": {
+ "version": "3.0.2",
+ "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz",
+ "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==",
+ "dev": true,
+ "requires": {
+ "glob": "^7.1.3"
+ }
+ },
+ "strip-ansi": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz",
+ "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==",
+ "dev": true,
+ "requires": {
+ "ansi-regex": "^5.0.0"
+ }
+ }
+ }
+ },
+ "@jest/environment": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-26.1.0.tgz",
+ "integrity": "sha512-86+DNcGongbX7ai/KE/S3/NcUVZfrwvFzOOWX/W+OOTvTds7j07LtC+MgGydH5c8Ri3uIrvdmVgd1xFD5zt/xA==",
+ "dev": true,
+ "requires": {
+ "@jest/fake-timers": "^26.1.0",
+ "@jest/types": "^26.1.0",
+ "jest-mock": "^26.1.0"
+ },
+ "dependencies": {
+ "@jest/types": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.1.0.tgz",
+ "integrity": "sha512-GXigDDsp6ZlNMhXQDeuy/iYCDsRIHJabWtDzvnn36+aqFfG14JmFV0e/iXxY4SP9vbXSiPNOWdehU5MeqrYHBQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0"
+ }
+ },
+ "chalk": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+ "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ }
+ }
+ },
+ "@jest/fake-timers": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-26.1.0.tgz",
+ "integrity": "sha512-Y5F3kBVWxhau3TJ825iuWy++BAuQzK/xEa+wD9vDH3RytW9f2DbMVodfUQC54rZDX3POqdxCgcKdgcOL0rYUpA==",
+ "dev": true,
+ "requires": {
+ "@jest/types": "^26.1.0",
+ "@sinonjs/fake-timers": "^6.0.1",
+ "jest-message-util": "^26.1.0",
+ "jest-mock": "^26.1.0",
+ "jest-util": "^26.1.0"
+ },
+ "dependencies": {
+ "@jest/types": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.1.0.tgz",
+ "integrity": "sha512-GXigDDsp6ZlNMhXQDeuy/iYCDsRIHJabWtDzvnn36+aqFfG14JmFV0e/iXxY4SP9vbXSiPNOWdehU5MeqrYHBQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0"
+ }
+ },
+ "chalk": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+ "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ }
+ }
+ },
+ "@jest/globals": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/globals/-/globals-26.1.0.tgz",
+ "integrity": "sha512-MKiHPNaT+ZoG85oMaYUmGHEqu98y3WO2yeIDJrs2sJqHhYOy3Z6F7F/luzFomRQ8SQ1wEkmahFAz2291Iv8EAw==",
+ "dev": true,
+ "requires": {
+ "@jest/environment": "^26.1.0",
+ "@jest/types": "^26.1.0",
+ "expect": "^26.1.0"
+ },
+ "dependencies": {
+ "@jest/types": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.1.0.tgz",
+ "integrity": "sha512-GXigDDsp6ZlNMhXQDeuy/iYCDsRIHJabWtDzvnn36+aqFfG14JmFV0e/iXxY4SP9vbXSiPNOWdehU5MeqrYHBQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0"
+ }
+ },
+ "chalk": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+ "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ }
+ }
+ },
+ "@jest/reporters": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/reporters/-/reporters-26.1.0.tgz",
+ "integrity": "sha512-SVAysur9FOIojJbF4wLP0TybmqwDkdnFxHSPzHMMIYyBtldCW9gG+Q5xWjpMFyErDiwlRuPyMSJSU64A67Pazg==",
+ "dev": true,
+ "requires": {
+ "@bcoe/v8-coverage": "^0.2.3",
+ "@jest/console": "^26.1.0",
+ "@jest/test-result": "^26.1.0",
+ "@jest/transform": "^26.1.0",
+ "@jest/types": "^26.1.0",
+ "chalk": "^4.0.0",
+ "collect-v8-coverage": "^1.0.0",
+ "exit": "^0.1.2",
+ "glob": "^7.1.2",
+ "graceful-fs": "^4.2.4",
+ "istanbul-lib-coverage": "^3.0.0",
+ "istanbul-lib-instrument": "^4.0.3",
+ "istanbul-lib-report": "^3.0.0",
+ "istanbul-lib-source-maps": "^4.0.0",
+ "istanbul-reports": "^3.0.2",
+ "jest-haste-map": "^26.1.0",
+ "jest-resolve": "^26.1.0",
+ "jest-util": "^26.1.0",
+ "jest-worker": "^26.1.0",
+ "node-notifier": "^7.0.0",
+ "slash": "^3.0.0",
+ "source-map": "^0.6.0",
+ "string-length": "^4.0.1",
+ "terminal-link": "^2.0.0",
+ "v8-to-istanbul": "^4.1.3"
+ },
+ "dependencies": {
+ "@jest/types": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.1.0.tgz",
+ "integrity": "sha512-GXigDDsp6ZlNMhXQDeuy/iYCDsRIHJabWtDzvnn36+aqFfG14JmFV0e/iXxY4SP9vbXSiPNOWdehU5MeqrYHBQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0"
+ }
+ },
+ "chalk": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+ "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ }
+ }
+ },
+ "@jest/source-map": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/source-map/-/source-map-26.1.0.tgz",
+ "integrity": "sha512-XYRPYx4eEVX15cMT9mstnO7hkHP3krNtKfxUYd8L7gbtia8JvZZ6bMzSwa6IQJENbudTwKMw5R1BePRD+bkEmA==",
+ "dev": true,
+ "requires": {
+ "callsites": "^3.0.0",
+ "graceful-fs": "^4.2.4",
+ "source-map": "^0.6.0"
+ }
+ },
+ "@jest/test-result": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/test-result/-/test-result-26.1.0.tgz",
+ "integrity": "sha512-Xz44mhXph93EYMA8aYDz+75mFbarTV/d/x0yMdI3tfSRs/vh4CqSxgzVmCps1fPkHDCtn0tU8IH9iCKgGeGpfw==",
+ "dev": true,
+ "requires": {
+ "@jest/console": "^26.1.0",
+ "@jest/types": "^26.1.0",
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "collect-v8-coverage": "^1.0.0"
+ },
+ "dependencies": {
+ "@jest/types": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.1.0.tgz",
+ "integrity": "sha512-GXigDDsp6ZlNMhXQDeuy/iYCDsRIHJabWtDzvnn36+aqFfG14JmFV0e/iXxY4SP9vbXSiPNOWdehU5MeqrYHBQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0"
+ }
+ },
+ "chalk": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+ "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ }
+ }
+ },
+ "@jest/test-sequencer": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/test-sequencer/-/test-sequencer-26.1.0.tgz",
+ "integrity": "sha512-Z/hcK+rTq56E6sBwMoQhSRDVjqrGtj1y14e2bIgcowARaIE1SgOanwx6gvY4Q9gTKMoZQXbXvptji+q5GYxa6Q==",
+ "dev": true,
+ "requires": {
+ "@jest/test-result": "^26.1.0",
+ "graceful-fs": "^4.2.4",
+ "jest-haste-map": "^26.1.0",
+ "jest-runner": "^26.1.0",
+ "jest-runtime": "^26.1.0"
+ }
+ },
+ "@jest/transform": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/transform/-/transform-26.1.0.tgz",
+ "integrity": "sha512-ICPm6sUXmZJieq45ix28k0s+d/z2E8CHDsq+WwtWI6kW8m7I8kPqarSEcUN86entHQ570ZBRci5OWaKL0wlAWw==",
+ "dev": true,
+ "requires": {
+ "@babel/core": "^7.1.0",
+ "@jest/types": "^26.1.0",
+ "babel-plugin-istanbul": "^6.0.0",
+ "chalk": "^4.0.0",
+ "convert-source-map": "^1.4.0",
+ "fast-json-stable-stringify": "^2.0.0",
+ "graceful-fs": "^4.2.4",
+ "jest-haste-map": "^26.1.0",
+ "jest-regex-util": "^26.0.0",
+ "jest-util": "^26.1.0",
+ "micromatch": "^4.0.2",
+ "pirates": "^4.0.1",
+ "slash": "^3.0.0",
+ "source-map": "^0.6.1",
+ "write-file-atomic": "^3.0.0"
+ },
+ "dependencies": {
+ "@jest/types": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.1.0.tgz",
+ "integrity": "sha512-GXigDDsp6ZlNMhXQDeuy/iYCDsRIHJabWtDzvnn36+aqFfG14JmFV0e/iXxY4SP9vbXSiPNOWdehU5MeqrYHBQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0"
+ }
+ },
+ "chalk": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+ "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ }
+ }
+ },
+ "@jest/types": {
+ "version": "25.5.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-25.5.0.tgz",
+ "integrity": "sha512-OXD0RgQ86Tu3MazKo8bnrkDRaDXXMGUqd+kTtLtK1Zb7CRzQcaSRPPPV37SvYTdevXEBVxe0HXylEjs8ibkmCw==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^3.0.0"
+ }
+ },
+ "@sinonjs/commons": {
+ "version": "1.8.0",
+ "resolved": "https://registry.npmjs.org/@sinonjs/commons/-/commons-1.8.0.tgz",
+ "integrity": "sha512-wEj54PfsZ5jGSwMX68G8ZXFawcSglQSXqCftWX3ec8MDUzQdHgcKvw97awHbY0efQEL5iKUOAmmVtoYgmrSG4Q==",
+ "dev": true,
+ "requires": {
+ "type-detect": "4.0.8"
+ }
+ },
+ "@sinonjs/fake-timers": {
+ "version": "6.0.1",
+ "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-6.0.1.tgz",
+ "integrity": "sha512-MZPUxrmFubI36XS1DI3qmI0YdN1gks62JtFZvxR67ljjSNCeK6U08Zx4msEWOXuofgqUt6zPHSi1H9fbjR/NRA==",
+ "dev": true,
+ "requires": {
+ "@sinonjs/commons": "^1.7.0"
+ }
+ },
+ "@types/babel__core": {
+ "version": "7.1.9",
+ "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.1.9.tgz",
+ "integrity": "sha512-sY2RsIJ5rpER1u3/aQ8OFSI7qGIy8o1NEEbgb2UaJcvOtXOMpd39ko723NBpjQFg9SIX7TXtjejZVGeIMLhoOw==",
+ "dev": true,
+ "requires": {
+ "@babel/parser": "^7.1.0",
+ "@babel/types": "^7.0.0",
+ "@types/babel__generator": "*",
+ "@types/babel__template": "*",
+ "@types/babel__traverse": "*"
+ }
+ },
+ "@types/babel__generator": {
+ "version": "7.6.1",
+ "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.1.tgz",
+ "integrity": "sha512-bBKm+2VPJcMRVwNhxKu8W+5/zT7pwNEqeokFOmbvVSqGzFneNxYcEBro9Ac7/N9tlsaPYnZLK8J1LWKkMsLAew==",
+ "dev": true,
+ "requires": {
+ "@babel/types": "^7.0.0"
+ }
+ },
+ "@types/babel__template": {
+ "version": "7.0.2",
+ "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.0.2.tgz",
+ "integrity": "sha512-/K6zCpeW7Imzgab2bLkLEbz0+1JlFSrUMdw7KoIIu+IUdu51GWaBZpd3y1VXGVXzynvGa4DaIaxNZHiON3GXUg==",
+ "dev": true,
+ "requires": {
+ "@babel/parser": "^7.1.0",
+ "@babel/types": "^7.0.0"
+ }
+ },
+ "@types/babel__traverse": {
+ "version": "7.0.13",
+ "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.0.13.tgz",
+ "integrity": "sha512-i+zS7t6/s9cdQvbqKDARrcbrPvtJGlbYsMkazo03nTAK3RX9FNrLllXys22uiTGJapPOTZTQ35nHh4ISph4SLQ==",
+ "dev": true,
+ "requires": {
+ "@babel/types": "^7.3.0"
+ }
+ },
"@types/codemirror": {
"version": "0.0.56",
"resolved": "https://registry.npmjs.org/@types/codemirror/-/codemirror-0.0.56.tgz",
"integrity": "sha512-OMtPqg2wFOEcNeVga+m+UXpYJw8ugISPCQOtShdFUho/k91Ms1oWOozoDT1I87Phv6IdwLfMLtIOahh1tO1cJQ==",
"dev": true
+ },
+ "@types/color-name": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/@types/color-name/-/color-name-1.1.1.tgz",
+ "integrity": "sha512-rr+OQyAjxze7GgWrSaJwydHStIhHq2lvY3BOC2Mj7KnzI7XK0Uw1TOOdI9lDoajEbSWLiYgoo4f1R51erQfhPQ==",
+ "dev": true
+ },
+ "@types/graceful-fs": {
+ "version": "4.1.3",
+ "resolved": "https://registry.npmjs.org/@types/graceful-fs/-/graceful-fs-4.1.3.tgz",
+ "integrity": "sha512-AiHRaEB50LQg0pZmm659vNBb9f4SJ0qrAnteuzhSeAUcJKxoYgEnprg/83kppCnc2zvtCKbdZry1a5pVY3lOTQ==",
+ "dev": true,
+ "requires": {
+ "@types/node": "*"
+ }
+ },
+ "@types/istanbul-lib-coverage": {
+ "version": "2.0.3",
+ "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.3.tgz",
+ "integrity": "sha512-sz7iLqvVUg1gIedBOvlkxPlc8/uVzyS5OwGz1cKjXzkl3FpL3al0crU8YGU1WoHkxn0Wxbw5tyi6hvzJKNzFsw==",
+ "dev": true
+ },
+ "@types/istanbul-lib-report": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/@types/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz",
+ "integrity": "sha512-plGgXAPfVKFoYfa9NpYDAkseG+g6Jr294RqeqcqDixSbU34MZVJRi/P+7Y8GDpzkEwLaGZZOpKIEmeVZNtKsrg==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "*"
+ }
+ },
+ "@types/istanbul-reports": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/@types/istanbul-reports/-/istanbul-reports-1.1.2.tgz",
+ "integrity": "sha512-P/W9yOX/3oPZSpaYOCQzGqgCQRXn0FFO/V8bWrCQs+wLmvVVxk6CRBXALEvNs9OHIatlnlFokfhuDo2ug01ciw==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "*",
+ "@types/istanbul-lib-report": "*"
+ }
+ },
+ "@types/jest": {
+ "version": "26.0.4",
+ "resolved": "https://registry.npmjs.org/@types/jest/-/jest-26.0.4.tgz",
+ "integrity": "sha512-4fQNItvelbNA9+sFgU+fhJo8ZFF+AS4Egk3GWwCW2jFtViukXbnztccafAdLhzE/0EiCogljtQQXP8aQ9J7sFg==",
+ "dev": true,
+ "requires": {
+ "jest-diff": "^25.2.1",
+ "pretty-format": "^25.2.1"
+ }
+ },
+ "@types/node": {
+ "version": "14.0.23",
+ "resolved": "https://registry.npmjs.org/@types/node/-/node-14.0.23.tgz",
+ "integrity": "sha512-Z4U8yDAl5TFkmYsZdFPdjeMa57NOvnaf1tljHzhouaPEp7LCj2JKkejpI1ODviIAQuW4CcQmxkQ77rnLsOOoKw==",
+ "dev": true
+ },
+ "@types/normalize-package-data": {
+ "version": "2.4.0",
+ "resolved": "https://registry.npmjs.org/@types/normalize-package-data/-/normalize-package-data-2.4.0.tgz",
+ "integrity": "sha512-f5j5b/Gf71L+dbqxIpQ4Z2WlmI/mPJ0fOkGGmFgtb6sAu97EPczzbS3/tJKxmcYDj55OX6ssqwDAWOHIYDRDGA==",
+ "dev": true
+ },
+ "@types/prettier": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/@types/prettier/-/prettier-2.0.2.tgz",
+ "integrity": "sha512-IkVfat549ggtkZUthUzEX49562eGikhSYeVGX97SkMFn+sTZrgRewXjQ4tPKFPCykZHkX1Zfd9OoELGqKU2jJA==",
+ "dev": true
+ },
+ "@types/stack-utils": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/@types/stack-utils/-/stack-utils-1.0.1.tgz",
+ "integrity": "sha512-l42BggppR6zLmpfU6fq9HEa2oGPEI8yrSPL3GITjfRInppYFahObbIQOQK3UGxEnyQpltZLaPe75046NOZQikw==",
+ "dev": true
+ },
+ "@types/yargs": {
+ "version": "15.0.5",
+ "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-15.0.5.tgz",
+ "integrity": "sha512-Dk/IDOPtOgubt/IaevIUbTgV7doaKkoorvOyYM2CMwuDyP89bekI7H4xLIwunNYiK9jhCkmc6pUrJk3cj2AB9w==",
+ "dev": true,
+ "requires": {
+ "@types/yargs-parser": "*"
+ }
+ },
+ "@types/yargs-parser": {
+ "version": "15.0.0",
+ "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-15.0.0.tgz",
+ "integrity": "sha512-FA/BWv8t8ZWJ+gEOnLLd8ygxH/2UFbAvgEonyfN6yWGLKc7zVjbpl2Y4CTjid9h2RfgPP6SEt6uHwEOply00yw==",
+ "dev": true
+ },
+ "abab": {
+ "version": "2.0.3",
+ "resolved": "https://registry.npmjs.org/abab/-/abab-2.0.3.tgz",
+ "integrity": "sha512-tsFzPpcttalNjFBCFMqsKYQcWxxen1pgJR56by//QwvJc4/OUS3kPOOttx2tSIfjsylB0pYu7f5D3K1RCxUnUg==",
+ "dev": true
+ },
+ "abbrev": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz",
+ "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==",
+ "dev": true
+ },
+ "acorn": {
+ "version": "7.3.1",
+ "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.3.1.tgz",
+ "integrity": "sha512-tLc0wSnatxAQHVHUapaHdz72pi9KUyHjq5KyHjGg9Y8Ifdc79pTh2XvI6I1/chZbnM7QtNKzh66ooDogPZSleA==",
+ "dev": true
+ },
+ "acorn-globals": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmjs.org/acorn-globals/-/acorn-globals-6.0.0.tgz",
+ "integrity": "sha512-ZQl7LOWaF5ePqqcX4hLuv/bLXYQNfNWw2c0/yX/TsPRKamzHcTGQnlCjHT3TsmkOUVEPS3crCxiPfdzE/Trlhg==",
+ "dev": true,
+ "requires": {
+ "acorn": "^7.1.1",
+ "acorn-walk": "^7.1.1"
+ }
+ },
+ "acorn-walk": {
+ "version": "7.2.0",
+ "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-7.2.0.tgz",
+ "integrity": "sha512-OPdCF6GsMIP+Az+aWfAAOEt2/+iVDKE7oy6lJ098aoe59oAmK76qV6Gw60SbZ8jHuG2wH058GF4pLFbYamYrVA==",
+ "dev": true
+ },
+ "ajv": {
+ "version": "6.12.3",
+ "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.3.tgz",
+ "integrity": "sha512-4K0cK3L1hsqk9xIb2z9vs/XU+PGJZ9PNpJRDS9YLzmNdX6jmVPfamLvTJr0aDAusnHyCHO6MjzlkAsgtqp9teA==",
+ "dev": true,
+ "requires": {
+ "fast-deep-equal": "^3.1.1",
+ "fast-json-stable-stringify": "^2.0.0",
+ "json-schema-traverse": "^0.4.1",
+ "uri-js": "^4.2.2"
+ }
+ },
+ "ansi-escapes": {
+ "version": "4.3.1",
+ "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.1.tgz",
+ "integrity": "sha512-JWF7ocqNrp8u9oqpgV+wH5ftbt+cfvv+PTjOvKLT3AdYly/LmORARfEVT1iyjwN+4MqE5UmVKoAdIBqeoCHgLA==",
+ "dev": true,
+ "requires": {
+ "type-fest": "^0.11.0"
+ },
+ "dependencies": {
+ "type-fest": {
+ "version": "0.11.0",
+ "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.11.0.tgz",
+ "integrity": "sha512-OdjXJxnCN1AvyLSzeKIgXTXxV+99ZuXl3Hpo9XpJAv9MBcHrrJOQ5kV7ypXOuQie+AmWG25hLbiKdwYTifzcfQ==",
+ "dev": true
+ }
+ }
+ },
+ "ansi-regex": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz",
+ "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==",
+ "dev": true
+ },
+ "ansi-styles": {
+ "version": "4.2.1",
+ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.2.1.tgz",
+ "integrity": "sha512-9VGjrMsG1vePxcSweQsN20KY/c4zN0h9fLjqAbwbPfahM3t+NL+M9HC8xeXG2I8pX5NoamTGNuomEUFI7fcUjA==",
+ "dev": true,
+ "requires": {
+ "@types/color-name": "^1.1.1",
+ "color-convert": "^2.0.1"
+ }
+ },
+ "anymatch": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.1.tgz",
+ "integrity": "sha512-mM8522psRCqzV+6LhomX5wgp25YVibjh8Wj23I5RPkPppSVSjyKD2A2mBJmWGa+KN7f2D6LNh9jkBCeyLktzjg==",
+ "dev": true,
+ "requires": {
+ "normalize-path": "^3.0.0",
+ "picomatch": "^2.0.4"
+ }
+ },
+ "aproba": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/aproba/-/aproba-1.2.0.tgz",
+ "integrity": "sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw==",
+ "dev": true
+ },
+ "are-we-there-yet": {
+ "version": "1.1.5",
+ "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-1.1.5.tgz",
+ "integrity": "sha512-5hYdAkZlcG8tOLujVDTgCT+uPX0VnpAH28gWsLfzpXYm7wP6mp5Q/gYyR7YQ0cKVJcXJnl3j2kpBan13PtQf6w==",
+ "dev": true,
+ "requires": {
+ "delegates": "^1.0.0",
+ "readable-stream": "^2.0.6"
+ }
+ },
+ "argparse": {
+ "version": "1.0.10",
+ "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz",
+ "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==",
+ "dev": true,
+ "requires": {
+ "sprintf-js": "~1.0.2"
+ }
+ },
+ "arr-diff": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-4.0.0.tgz",
+ "integrity": "sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA=",
+ "dev": true
+ },
+ "arr-flatten": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz",
+ "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==",
+ "dev": true
+ },
+ "arr-union": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/arr-union/-/arr-union-3.1.0.tgz",
+ "integrity": "sha1-45sJrqne+Gao8gbiiK9jkZuuOcQ=",
+ "dev": true
+ },
+ "array-unique": {
+ "version": "0.3.2",
+ "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.3.2.tgz",
+ "integrity": "sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=",
+ "dev": true
+ },
+ "asn1": {
+ "version": "0.2.4",
+ "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.4.tgz",
+ "integrity": "sha512-jxwzQpLQjSmWXgwaCZE9Nz+glAG01yF1QnWgbhGwHI5A6FRIEY6IVqtHhIepHqI7/kyEyQEagBC5mBEFlIYvdg==",
+ "dev": true,
+ "requires": {
+ "safer-buffer": "~2.1.0"
+ }
+ },
+ "assert-plus": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz",
+ "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=",
+ "dev": true
+ },
+ "assign-symbols": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/assign-symbols/-/assign-symbols-1.0.0.tgz",
+ "integrity": "sha1-WWZ/QfrdTyDMvCu5a41Pf3jsA2c=",
+ "dev": true
+ },
+ "asynckit": {
+ "version": "0.4.0",
+ "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz",
+ "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=",
+ "dev": true
+ },
+ "atob": {
+ "version": "2.1.2",
+ "resolved": "https://registry.npmjs.org/atob/-/atob-2.1.2.tgz",
+ "integrity": "sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg==",
+ "dev": true
+ },
+ "aws-sign2": {
+ "version": "0.7.0",
+ "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz",
+ "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=",
+ "dev": true
+ },
+ "aws4": {
+ "version": "1.10.0",
+ "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.10.0.tgz",
+ "integrity": "sha512-3YDiu347mtVtjpyV3u5kVqQLP242c06zwDOgpeRnybmXlYYsLbtTrUBUm8i8srONt+FWobl5aibnU1030PeeuA==",
+ "dev": true
+ },
+ "babel-jest": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/babel-jest/-/babel-jest-26.1.0.tgz",
+ "integrity": "sha512-Nkqgtfe7j6PxLO6TnCQQlkMm8wdTdnIF8xrdpooHCuD5hXRzVEPbPneTJKknH5Dsv3L8ip9unHDAp48YQ54Dkg==",
+ "dev": true,
+ "requires": {
+ "@jest/transform": "^26.1.0",
+ "@jest/types": "^26.1.0",
+ "@types/babel__core": "^7.1.7",
+ "babel-plugin-istanbul": "^6.0.0",
+ "babel-preset-jest": "^26.1.0",
+ "chalk": "^4.0.0",
+ "graceful-fs": "^4.2.4",
+ "slash": "^3.0.0"
+ },
+ "dependencies": {
+ "@jest/types": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.1.0.tgz",
+ "integrity": "sha512-GXigDDsp6ZlNMhXQDeuy/iYCDsRIHJabWtDzvnn36+aqFfG14JmFV0e/iXxY4SP9vbXSiPNOWdehU5MeqrYHBQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0"
+ }
+ },
+ "chalk": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+ "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ }
+ }
+ },
+ "babel-plugin-istanbul": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-6.0.0.tgz",
+ "integrity": "sha512-AF55rZXpe7trmEylbaE1Gv54wn6rwU03aptvRoVIGP8YykoSxqdVLV1TfwflBCE/QtHmqtP8SWlTENqbK8GCSQ==",
+ "dev": true,
+ "requires": {
+ "@babel/helper-plugin-utils": "^7.0.0",
+ "@istanbuljs/load-nyc-config": "^1.0.0",
+ "@istanbuljs/schema": "^0.1.2",
+ "istanbul-lib-instrument": "^4.0.0",
+ "test-exclude": "^6.0.0"
+ }
+ },
+ "babel-plugin-jest-hoist": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-26.1.0.tgz",
+ "integrity": "sha512-qhqLVkkSlqmC83bdMhM8WW4Z9tB+JkjqAqlbbohS9sJLT5Ha2vfzuKqg5yenXrAjOPG2YC0WiXdH3a9PvB+YYw==",
+ "dev": true,
+ "requires": {
+ "@babel/template": "^7.3.3",
+ "@babel/types": "^7.3.3",
+ "@types/babel__core": "^7.0.0",
+ "@types/babel__traverse": "^7.0.6"
+ }
+ },
+ "babel-preset-current-node-syntax": {
+ "version": "0.1.3",
+ "resolved": "https://registry.npmjs.org/babel-preset-current-node-syntax/-/babel-preset-current-node-syntax-0.1.3.tgz",
+ "integrity": "sha512-uyexu1sVwcdFnyq9o8UQYsXwXflIh8LvrF5+cKrYam93ned1CStffB3+BEcsxGSgagoA3GEyjDqO4a/58hyPYQ==",
+ "dev": true,
+ "requires": {
+ "@babel/plugin-syntax-async-generators": "^7.8.4",
+ "@babel/plugin-syntax-bigint": "^7.8.3",
+ "@babel/plugin-syntax-class-properties": "^7.8.3",
+ "@babel/plugin-syntax-import-meta": "^7.8.3",
+ "@babel/plugin-syntax-json-strings": "^7.8.3",
+ "@babel/plugin-syntax-logical-assignment-operators": "^7.8.3",
+ "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3",
+ "@babel/plugin-syntax-numeric-separator": "^7.8.3",
+ "@babel/plugin-syntax-object-rest-spread": "^7.8.3",
+ "@babel/plugin-syntax-optional-catch-binding": "^7.8.3",
+ "@babel/plugin-syntax-optional-chaining": "^7.8.3"
+ }
+ },
+ "babel-preset-jest": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/babel-preset-jest/-/babel-preset-jest-26.1.0.tgz",
+ "integrity": "sha512-na9qCqFksknlEj5iSdw1ehMVR06LCCTkZLGKeEtxDDdhg8xpUF09m29Kvh1pRbZ07h7AQ5ttLYUwpXL4tO6w7w==",
+ "dev": true,
+ "requires": {
+ "babel-plugin-jest-hoist": "^26.1.0",
+ "babel-preset-current-node-syntax": "^0.1.2"
+ }
+ },
+ "balanced-match": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz",
+ "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=",
+ "dev": true
+ },
+ "base": {
+ "version": "0.11.2",
+ "resolved": "https://registry.npmjs.org/base/-/base-0.11.2.tgz",
+ "integrity": "sha512-5T6P4xPgpp0YDFvSWwEZ4NoE3aM4QBQXDzmVbraCkFj8zHM+mba8SyqB5DbZWyR7mYHo6Y7BdQo3MoA4m0TeQg==",
+ "dev": true,
+ "requires": {
+ "cache-base": "^1.0.1",
+ "class-utils": "^0.3.5",
+ "component-emitter": "^1.2.1",
+ "define-property": "^1.0.0",
+ "isobject": "^3.0.1",
+ "mixin-deep": "^1.2.0",
+ "pascalcase": "^0.1.1"
+ },
+ "dependencies": {
+ "define-property": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz",
+ "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=",
+ "dev": true,
+ "requires": {
+ "is-descriptor": "^1.0.0"
+ }
+ },
+ "is-accessor-descriptor": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz",
+ "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==",
+ "dev": true,
+ "requires": {
+ "kind-of": "^6.0.0"
+ }
+ },
+ "is-data-descriptor": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz",
+ "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==",
+ "dev": true,
+ "requires": {
+ "kind-of": "^6.0.0"
+ }
+ },
+ "is-descriptor": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz",
+ "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==",
+ "dev": true,
+ "requires": {
+ "is-accessor-descriptor": "^1.0.0",
+ "is-data-descriptor": "^1.0.0",
+ "kind-of": "^6.0.2"
+ }
+ }
+ }
+ },
+ "bcrypt-pbkdf": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz",
+ "integrity": "sha1-pDAdOJtqQ/m2f/PKEaP2Y342Dp4=",
+ "dev": true,
+ "requires": {
+ "tweetnacl": "^0.14.3"
+ }
+ },
+ "brace-expansion": {
+ "version": "1.1.11",
+ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
+ "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
+ "dev": true,
+ "requires": {
+ "balanced-match": "^1.0.0",
+ "concat-map": "0.0.1"
+ }
+ },
+ "braces": {
+ "version": "3.0.2",
+ "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz",
+ "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==",
+ "dev": true,
+ "requires": {
+ "fill-range": "^7.0.1"
+ }
+ },
+ "browser-process-hrtime": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/browser-process-hrtime/-/browser-process-hrtime-1.0.0.tgz",
+ "integrity": "sha512-9o5UecI3GhkpM6DrXr69PblIuWxPKk9Y0jHBRhdocZ2y7YECBFCsHm79Pr3OyR2AvjhDkabFJaDJMYRazHgsow==",
+ "dev": true
+ },
+ "bs-logger": {
+ "version": "0.2.6",
+ "resolved": "https://registry.npmjs.org/bs-logger/-/bs-logger-0.2.6.tgz",
+ "integrity": "sha512-pd8DCoxmbgc7hyPKOvxtqNcjYoOsABPQdcCUjGp3d42VR2CX1ORhk2A87oqqu5R1kk+76nsxZupkmyd+MVtCog==",
+ "dev": true,
+ "requires": {
+ "fast-json-stable-stringify": "2.x"
+ }
+ },
+ "bser": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/bser/-/bser-2.1.1.tgz",
+ "integrity": "sha512-gQxTNE/GAfIIrmHLUE3oJyp5FO6HRBfhjnw4/wMmA63ZGDJnWBmgY/lyQBpnDUkGmAhbSe39tx2d/iTOAfglwQ==",
+ "dev": true,
+ "requires": {
+ "node-int64": "^0.4.0"
+ }
+ },
+ "buffer-from": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.1.tgz",
+ "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==",
+ "dev": true
+ },
+ "cache-base": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/cache-base/-/cache-base-1.0.1.tgz",
+ "integrity": "sha512-AKcdTnFSWATd5/GCPRxr2ChwIJ85CeyrEyjRHlKxQ56d4XJMGym0uAiKn0xbLOGOl3+yRpOTi484dVCEc5AUzQ==",
+ "dev": true,
+ "requires": {
+ "collection-visit": "^1.0.0",
+ "component-emitter": "^1.2.1",
+ "get-value": "^2.0.6",
+ "has-value": "^1.0.0",
+ "isobject": "^3.0.1",
+ "set-value": "^2.0.0",
+ "to-object-path": "^0.3.0",
+ "union-value": "^1.0.0",
+ "unset-value": "^1.0.0"
+ }
+ },
+ "callsites": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz",
+ "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==",
+ "dev": true
+ },
+ "camelcase": {
+ "version": "5.3.1",
+ "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz",
+ "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==",
+ "dev": true
+ },
+ "canvas": {
+ "version": "2.6.1",
+ "resolved": "https://registry.npmjs.org/canvas/-/canvas-2.6.1.tgz",
+ "integrity": "sha512-S98rKsPcuhfTcYbtF53UIJhcbgIAK533d1kJKMwsMwAIFgfd58MOyxRud3kktlzWiEkFliaJtvyZCBtud/XVEA==",
+ "dev": true,
+ "requires": {
+ "nan": "^2.14.0",
+ "node-pre-gyp": "^0.11.0",
+ "simple-get": "^3.0.3"
+ }
+ },
+ "capture-exit": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/capture-exit/-/capture-exit-2.0.0.tgz",
+ "integrity": "sha512-PiT/hQmTonHhl/HFGN+Lx3JJUznrVYJ3+AQsnthneZbvW7x+f08Tk7yLJTLEOUvBTbduLeeBkxEaYXUOUrRq6g==",
+ "dev": true,
+ "requires": {
+ "rsvp": "^4.8.4"
+ }
+ },
+ "caseless": {
+ "version": "0.12.0",
+ "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz",
+ "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=",
+ "dev": true
+ },
+ "chalk": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-3.0.0.tgz",
+ "integrity": "sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ },
+ "char-regex": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/char-regex/-/char-regex-1.0.2.tgz",
+ "integrity": "sha512-kWWXztvZ5SBQV+eRgKFeh8q5sLuZY2+8WUIzlxWVTg+oGwY14qylx1KbKzHd8P6ZYkAg0xyIDU9JMHhyJMZ1jw==",
+ "dev": true
+ },
+ "chownr": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/chownr/-/chownr-1.1.4.tgz",
+ "integrity": "sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg==",
+ "dev": true
+ },
+ "ci-info": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-2.0.0.tgz",
+ "integrity": "sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ==",
+ "dev": true
+ },
+ "class-utils": {
+ "version": "0.3.6",
+ "resolved": "https://registry.npmjs.org/class-utils/-/class-utils-0.3.6.tgz",
+ "integrity": "sha512-qOhPa/Fj7s6TY8H8esGu5QNpMMQxz79h+urzrNYN6mn+9BnxlDGf5QZ+XeCDsxSjPqsSR56XOZOJmpeurnLMeg==",
+ "dev": true,
+ "requires": {
+ "arr-union": "^3.1.0",
+ "define-property": "^0.2.5",
+ "isobject": "^3.0.0",
+ "static-extend": "^0.1.1"
+ },
+ "dependencies": {
+ "define-property": {
+ "version": "0.2.5",
+ "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz",
+ "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=",
+ "dev": true,
+ "requires": {
+ "is-descriptor": "^0.1.0"
+ }
+ }
+ }
+ },
+ "cliui": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmjs.org/cliui/-/cliui-6.0.0.tgz",
+ "integrity": "sha512-t6wbgtoCXvAzst7QgXxJYqPt0usEfbgQdftEPbLL/cvv6HPE5VgvqCuAIDR0NgU52ds6rFwqrgakNLrHEjCbrQ==",
+ "dev": true,
+ "requires": {
+ "string-width": "^4.2.0",
+ "strip-ansi": "^6.0.0",
+ "wrap-ansi": "^6.2.0"
+ },
+ "dependencies": {
+ "is-fullwidth-code-point": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz",
+ "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==",
+ "dev": true
+ },
+ "string-width": {
+ "version": "4.2.0",
+ "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz",
+ "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==",
+ "dev": true,
+ "requires": {
+ "emoji-regex": "^8.0.0",
+ "is-fullwidth-code-point": "^3.0.0",
+ "strip-ansi": "^6.0.0"
+ }
+ },
+ "strip-ansi": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz",
+ "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==",
+ "dev": true,
+ "requires": {
+ "ansi-regex": "^5.0.0"
+ }
+ }
+ }
+ },
+ "co": {
+ "version": "4.6.0",
+ "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz",
+ "integrity": "sha1-bqa989hTrlTMuOR7+gvz+QMfsYQ=",
+ "dev": true
+ },
+ "code-point-at": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz",
+ "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=",
+ "dev": true
+ },
+ "collect-v8-coverage": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/collect-v8-coverage/-/collect-v8-coverage-1.0.1.tgz",
+ "integrity": "sha512-iBPtljfCNcTKNAto0KEtDfZ3qzjJvqE3aTGZsbhjSBlorqpXJlaWWtPO35D+ZImoC3KWejX64o+yPGxhWSTzfg==",
+ "dev": true
+ },
+ "collection-visit": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/collection-visit/-/collection-visit-1.0.0.tgz",
+ "integrity": "sha1-S8A3PBZLwykbTTaMgpzxqApZ3KA=",
+ "dev": true,
+ "requires": {
+ "map-visit": "^1.0.0",
+ "object-visit": "^1.0.0"
+ }
+ },
+ "color-convert": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+ "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
+ "dev": true,
+ "requires": {
+ "color-name": "~1.1.4"
+ }
+ },
+ "color-name": {
+ "version": "1.1.4",
+ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+ "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
+ "dev": true
+ },
+ "combined-stream": {
+ "version": "1.0.8",
+ "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz",
+ "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==",
+ "dev": true,
+ "requires": {
+ "delayed-stream": "~1.0.0"
+ }
+ },
+ "component-emitter": {
+ "version": "1.3.0",
+ "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.3.0.tgz",
+ "integrity": "sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg==",
+ "dev": true
+ },
+ "concat-map": {
+ "version": "0.0.1",
+ "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
+ "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=",
+ "dev": true
+ },
+ "console-control-strings": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz",
+ "integrity": "sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4=",
+ "dev": true
+ },
+ "convert-source-map": {
+ "version": "1.7.0",
+ "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.7.0.tgz",
+ "integrity": "sha512-4FJkXzKXEDB1snCFZlLP4gpC3JILicCpGbzG9f9G7tGqGCzETQ2hWPrcinA9oU4wtf2biUaEH5065UnMeR33oA==",
+ "dev": true,
+ "requires": {
+ "safe-buffer": "~5.1.1"
+ }
+ },
+ "copy-descriptor": {
+ "version": "0.1.1",
+ "resolved": "https://registry.npmjs.org/copy-descriptor/-/copy-descriptor-0.1.1.tgz",
+ "integrity": "sha1-Z29us8OZl8LuGsOpJP1hJHSPV40=",
+ "dev": true
+ },
+ "core-util-is": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz",
+ "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=",
+ "dev": true
+ },
+ "cross-spawn": {
+ "version": "6.0.5",
+ "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz",
+ "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==",
+ "dev": true,
+ "requires": {
+ "nice-try": "^1.0.4",
+ "path-key": "^2.0.1",
+ "semver": "^5.5.0",
+ "shebang-command": "^1.2.0",
+ "which": "^1.2.9"
+ },
+ "dependencies": {
+ "which": {
+ "version": "1.3.1",
+ "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz",
+ "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==",
+ "dev": true,
+ "requires": {
+ "isexe": "^2.0.0"
+ }
+ }
+ }
+ },
+ "cssom": {
+ "version": "0.4.4",
+ "resolved": "https://registry.npmjs.org/cssom/-/cssom-0.4.4.tgz",
+ "integrity": "sha512-p3pvU7r1MyyqbTk+WbNJIgJjG2VmTIaB10rI93LzVPrmDJKkzKYMtxxyAvQXR/NS6otuzveI7+7BBq3SjBS2mw==",
+ "dev": true
+ },
+ "cssstyle": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmjs.org/cssstyle/-/cssstyle-2.3.0.tgz",
+ "integrity": "sha512-AZL67abkUzIuvcHqk7c09cezpGNcxUxU4Ioi/05xHk4DQeTkWmGYftIE6ctU6AEt+Gn4n1lDStOtj7FKycP71A==",
+ "dev": true,
+ "requires": {
+ "cssom": "~0.3.6"
+ },
+ "dependencies": {
+ "cssom": {
+ "version": "0.3.8",
+ "resolved": "https://registry.npmjs.org/cssom/-/cssom-0.3.8.tgz",
+ "integrity": "sha512-b0tGHbfegbhPJpxpiBPU2sCkigAqtM9O121le6bbOlgyV+NyGyCmVfJ6QW9eRjz8CpNfWEOYBIMIGRYkLwsIYg==",
+ "dev": true
+ }
+ }
+ },
+ "dashdash": {
+ "version": "1.14.1",
+ "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz",
+ "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=",
+ "dev": true,
+ "requires": {
+ "assert-plus": "^1.0.0"
+ }
+ },
+ "data-urls": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/data-urls/-/data-urls-2.0.0.tgz",
+ "integrity": "sha512-X5eWTSXO/BJmpdIKCRuKUgSCgAN0OwliVK3yPKbwIWU1Tdw5BRajxlzMidvh+gwko9AfQ9zIj52pzF91Q3YAvQ==",
+ "dev": true,
+ "requires": {
+ "abab": "^2.0.3",
+ "whatwg-mimetype": "^2.3.0",
+ "whatwg-url": "^8.0.0"
+ }
+ },
+ "debug": {
+ "version": "3.2.6",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz",
+ "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==",
+ "dev": true,
+ "requires": {
+ "ms": "^2.1.1"
+ }
+ },
+ "decamelize": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz",
+ "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=",
+ "dev": true
+ },
+ "decimal.js": {
+ "version": "10.2.0",
+ "resolved": "https://registry.npmjs.org/decimal.js/-/decimal.js-10.2.0.tgz",
+ "integrity": "sha512-vDPw+rDgn3bZe1+F/pyEwb1oMG2XTlRVgAa6B4KccTEpYgF8w6eQllVbQcfIJnZyvzFtFpxnpGtx8dd7DJp/Rw==",
+ "dev": true
+ },
+ "decode-uri-component": {
+ "version": "0.2.0",
+ "resolved": "https://registry.npmjs.org/decode-uri-component/-/decode-uri-component-0.2.0.tgz",
+ "integrity": "sha1-6zkTMzRYd1y4TNGh+uBiEGu4dUU=",
+ "dev": true
+ },
+ "decompress-response": {
+ "version": "4.2.1",
+ "resolved": "https://registry.npmjs.org/decompress-response/-/decompress-response-4.2.1.tgz",
+ "integrity": "sha512-jOSne2qbyE+/r8G1VU+G/82LBs2Fs4LAsTiLSHOCOMZQl2OKZ6i8i4IyHemTe+/yIXOtTcRQMzPcgyhoFlqPkw==",
+ "dev": true,
+ "requires": {
+ "mimic-response": "^2.0.0"
+ }
+ },
+ "deep-extend": {
+ "version": "0.6.0",
+ "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz",
+ "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==",
+ "dev": true
+ },
+ "deep-is": {
+ "version": "0.1.3",
+ "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz",
+ "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=",
+ "dev": true
+ },
+ "deepmerge": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.2.2.tgz",
+ "integrity": "sha512-FJ3UgI4gIl+PHZm53knsuSFpE+nESMr7M4v9QcgB7S63Kj/6WqMiFQJpBBYz1Pt+66bZpP3Q7Lye0Oo9MPKEdg==",
+ "dev": true
+ },
+ "define-property": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/define-property/-/define-property-2.0.2.tgz",
+ "integrity": "sha512-jwK2UV4cnPpbcG7+VRARKTZPUWowwXA8bzH5NP6ud0oeAxyYPuGZUAC7hMugpCdz4BeSZl2Dl9k66CHJ/46ZYQ==",
+ "dev": true,
+ "requires": {
+ "is-descriptor": "^1.0.2",
+ "isobject": "^3.0.1"
+ },
+ "dependencies": {
+ "is-accessor-descriptor": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz",
+ "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==",
+ "dev": true,
+ "requires": {
+ "kind-of": "^6.0.0"
+ }
+ },
+ "is-data-descriptor": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz",
+ "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==",
+ "dev": true,
+ "requires": {
+ "kind-of": "^6.0.0"
+ }
+ },
+ "is-descriptor": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz",
+ "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==",
+ "dev": true,
+ "requires": {
+ "is-accessor-descriptor": "^1.0.0",
+ "is-data-descriptor": "^1.0.0",
+ "kind-of": "^6.0.2"
+ }
+ }
+ }
+ },
+ "delayed-stream": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz",
+ "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=",
+ "dev": true
+ },
+ "delegates": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz",
+ "integrity": "sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o=",
+ "dev": true
+ },
+ "detect-libc": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/detect-libc/-/detect-libc-1.0.3.tgz",
+ "integrity": "sha1-+hN8S9aY7fVc1c0CrFWfkaTEups=",
+ "dev": true
+ },
+ "detect-newline": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/detect-newline/-/detect-newline-3.1.0.tgz",
+ "integrity": "sha512-TLz+x/vEXm/Y7P7wn1EJFNLxYpUD4TgMosxY6fAVJUnJMbupHBOncxyWUG9OpTaH9EBD7uFI5LfEgmMOc54DsA==",
+ "dev": true
+ },
+ "diff-sequences": {
+ "version": "25.2.6",
+ "resolved": "https://registry.npmjs.org/diff-sequences/-/diff-sequences-25.2.6.tgz",
+ "integrity": "sha512-Hq8o7+6GaZeoFjtpgvRBUknSXNeJiCx7V9Fr94ZMljNiCr9n9L8H8aJqgWOQiDDGdyn29fRNcDdRVJ5fdyihfg==",
+ "dev": true
+ },
+ "domexception": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/domexception/-/domexception-2.0.1.tgz",
+ "integrity": "sha512-yxJ2mFy/sibVQlu5qHjOkf9J3K6zgmCxgJ94u2EdvDOV09H+32LtRswEcUsmUWN72pVLOEnTSRaIVVzVQgS0dg==",
+ "dev": true,
+ "requires": {
+ "webidl-conversions": "^5.0.0"
+ },
+ "dependencies": {
+ "webidl-conversions": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-5.0.0.tgz",
+ "integrity": "sha512-VlZwKPCkYKxQgeSbH5EyngOmRp7Ww7I9rQLERETtf5ofd9pGeswWiOtogpEO850jziPRarreGxn5QIiTqpb2wA==",
+ "dev": true
+ }
+ }
+ },
+ "ecc-jsbn": {
+ "version": "0.1.2",
+ "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz",
+ "integrity": "sha1-OoOpBOVDUyh4dMVkt1SThoSamMk=",
+ "dev": true,
+ "requires": {
+ "jsbn": "~0.1.0",
+ "safer-buffer": "^2.1.0"
+ }
+ },
+ "emoji-regex": {
+ "version": "8.0.0",
+ "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz",
+ "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==",
+ "dev": true
+ },
+ "end-of-stream": {
+ "version": "1.4.4",
+ "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz",
+ "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==",
+ "dev": true,
+ "requires": {
+ "once": "^1.4.0"
+ }
+ },
+ "error-ex": {
+ "version": "1.3.2",
+ "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz",
+ "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==",
+ "dev": true,
+ "requires": {
+ "is-arrayish": "^0.2.1"
+ }
+ },
+ "escape-string-regexp": {
+ "version": "1.0.5",
+ "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz",
+ "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=",
+ "dev": true
+ },
+ "escodegen": {
+ "version": "1.14.3",
+ "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-1.14.3.tgz",
+ "integrity": "sha512-qFcX0XJkdg+PB3xjZZG/wKSuT1PnQWx57+TVSjIMmILd2yC/6ByYElPwJnslDsuWuSAp4AwJGumarAAmJch5Kw==",
+ "dev": true,
+ "requires": {
+ "esprima": "^4.0.1",
+ "estraverse": "^4.2.0",
+ "esutils": "^2.0.2",
+ "optionator": "^0.8.1",
+ "source-map": "~0.6.1"
+ }
+ },
+ "esprima": {
+ "version": "4.0.1",
+ "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz",
+ "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==",
+ "dev": true
+ },
+ "estraverse": {
+ "version": "4.3.0",
+ "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz",
+ "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==",
+ "dev": true
+ },
+ "esutils": {
+ "version": "2.0.3",
+ "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz",
+ "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==",
+ "dev": true
+ },
+ "exec-sh": {
+ "version": "0.3.4",
+ "resolved": "https://registry.npmjs.org/exec-sh/-/exec-sh-0.3.4.tgz",
+ "integrity": "sha512-sEFIkc61v75sWeOe72qyrqg2Qg0OuLESziUDk/O/z2qgS15y2gWVFrI6f2Qn/qw/0/NCfCEsmNA4zOjkwEZT1A==",
+ "dev": true
+ },
+ "execa": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/execa/-/execa-1.0.0.tgz",
+ "integrity": "sha512-adbxcyWV46qiHyvSp50TKt05tB4tK3HcmF7/nxfAdhnox83seTDbwnaqKO4sXRy7roHAIFqJP/Rw/AuEbX61LA==",
+ "dev": true,
+ "requires": {
+ "cross-spawn": "^6.0.0",
+ "get-stream": "^4.0.0",
+ "is-stream": "^1.1.0",
+ "npm-run-path": "^2.0.0",
+ "p-finally": "^1.0.0",
+ "signal-exit": "^3.0.0",
+ "strip-eof": "^1.0.0"
+ }
+ },
+ "exit": {
+ "version": "0.1.2",
+ "resolved": "https://registry.npmjs.org/exit/-/exit-0.1.2.tgz",
+ "integrity": "sha1-BjJjj42HfMghB9MKD/8aF8uhzQw=",
+ "dev": true
+ },
+ "expand-brackets": {
+ "version": "2.1.4",
+ "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-2.1.4.tgz",
+ "integrity": "sha1-t3c14xXOMPa27/D4OwQVGiJEliI=",
+ "dev": true,
+ "requires": {
+ "debug": "^2.3.3",
+ "define-property": "^0.2.5",
+ "extend-shallow": "^2.0.1",
+ "posix-character-classes": "^0.1.0",
+ "regex-not": "^1.0.0",
+ "snapdragon": "^0.8.1",
+ "to-regex": "^3.0.1"
+ },
+ "dependencies": {
+ "debug": {
+ "version": "2.6.9",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
+ "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
+ "dev": true,
+ "requires": {
+ "ms": "2.0.0"
+ }
+ },
+ "define-property": {
+ "version": "0.2.5",
+ "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz",
+ "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=",
+ "dev": true,
+ "requires": {
+ "is-descriptor": "^0.1.0"
+ }
+ },
+ "extend-shallow": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
+ "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
+ "dev": true,
+ "requires": {
+ "is-extendable": "^0.1.0"
+ }
+ },
+ "ms": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
+ "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=",
+ "dev": true
+ }
+ }
+ },
+ "expect": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/expect/-/expect-26.1.0.tgz",
+ "integrity": "sha512-QbH4LZXDsno9AACrN9eM0zfnby9G+OsdNgZUohjg/P0mLy1O+/bzTAJGT6VSIjVCe8yKM6SzEl/ckEOFBT7Vnw==",
+ "dev": true,
+ "requires": {
+ "@jest/types": "^26.1.0",
+ "ansi-styles": "^4.0.0",
+ "jest-get-type": "^26.0.0",
+ "jest-matcher-utils": "^26.1.0",
+ "jest-message-util": "^26.1.0",
+ "jest-regex-util": "^26.0.0"
+ },
+ "dependencies": {
+ "@jest/types": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.1.0.tgz",
+ "integrity": "sha512-GXigDDsp6ZlNMhXQDeuy/iYCDsRIHJabWtDzvnn36+aqFfG14JmFV0e/iXxY4SP9vbXSiPNOWdehU5MeqrYHBQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0"
+ }
+ },
+ "chalk": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+ "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ },
+ "jest-get-type": {
+ "version": "26.0.0",
+ "resolved": "https://registry.npmjs.org/jest-get-type/-/jest-get-type-26.0.0.tgz",
+ "integrity": "sha512-zRc1OAPnnws1EVfykXOj19zo2EMw5Hi6HLbFCSjpuJiXtOWAYIjNsHVSbpQ8bDX7L5BGYGI8m+HmKdjHYFF0kg==",
+ "dev": true
+ }
+ }
+ },
+ "extend": {
+ "version": "3.0.2",
+ "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz",
+ "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==",
+ "dev": true
+ },
+ "extend-shallow": {
+ "version": "3.0.2",
+ "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-3.0.2.tgz",
+ "integrity": "sha1-Jqcarwc7OfshJxcnRhMcJwQCjbg=",
+ "dev": true,
+ "requires": {
+ "assign-symbols": "^1.0.0",
+ "is-extendable": "^1.0.1"
+ },
+ "dependencies": {
+ "is-extendable": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz",
+ "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==",
+ "dev": true,
+ "requires": {
+ "is-plain-object": "^2.0.4"
+ }
+ }
+ }
+ },
+ "extglob": {
+ "version": "2.0.4",
+ "resolved": "https://registry.npmjs.org/extglob/-/extglob-2.0.4.tgz",
+ "integrity": "sha512-Nmb6QXkELsuBr24CJSkilo6UHHgbekK5UiZgfE6UHD3Eb27YC6oD+bhcT+tJ6cl8dmsgdQxnWlcry8ksBIBLpw==",
+ "dev": true,
+ "requires": {
+ "array-unique": "^0.3.2",
+ "define-property": "^1.0.0",
+ "expand-brackets": "^2.1.4",
+ "extend-shallow": "^2.0.1",
+ "fragment-cache": "^0.2.1",
+ "regex-not": "^1.0.0",
+ "snapdragon": "^0.8.1",
+ "to-regex": "^3.0.1"
+ },
+ "dependencies": {
+ "define-property": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz",
+ "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=",
+ "dev": true,
+ "requires": {
+ "is-descriptor": "^1.0.0"
+ }
+ },
+ "extend-shallow": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
+ "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
+ "dev": true,
+ "requires": {
+ "is-extendable": "^0.1.0"
+ }
+ },
+ "is-accessor-descriptor": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz",
+ "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==",
+ "dev": true,
+ "requires": {
+ "kind-of": "^6.0.0"
+ }
+ },
+ "is-data-descriptor": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz",
+ "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==",
+ "dev": true,
+ "requires": {
+ "kind-of": "^6.0.0"
+ }
+ },
+ "is-descriptor": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz",
+ "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==",
+ "dev": true,
+ "requires": {
+ "is-accessor-descriptor": "^1.0.0",
+ "is-data-descriptor": "^1.0.0",
+ "kind-of": "^6.0.2"
+ }
+ }
+ }
+ },
+ "extsprintf": {
+ "version": "1.3.0",
+ "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz",
+ "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=",
+ "dev": true
+ },
+ "fast-deep-equal": {
+ "version": "3.1.3",
+ "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz",
+ "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==",
+ "dev": true
+ },
+ "fast-json-stable-stringify": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz",
+ "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==",
+ "dev": true
+ },
+ "fast-levenshtein": {
+ "version": "2.0.6",
+ "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz",
+ "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=",
+ "dev": true
+ },
+ "fb-watchman": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/fb-watchman/-/fb-watchman-2.0.1.tgz",
+ "integrity": "sha512-DkPJKQeY6kKwmuMretBhr7G6Vodr7bFwDYTXIkfG1gjvNpaxBTQV3PbXg6bR1c1UP4jPOX0jHUbbHANL9vRjVg==",
+ "dev": true,
+ "requires": {
+ "bser": "2.1.1"
+ }
+ },
+ "fill-range": {
+ "version": "7.0.1",
+ "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz",
+ "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==",
+ "dev": true,
+ "requires": {
+ "to-regex-range": "^5.0.1"
+ }
+ },
+ "find-up": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz",
+ "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==",
+ "dev": true,
+ "requires": {
+ "locate-path": "^5.0.0",
+ "path-exists": "^4.0.0"
+ }
+ },
+ "for-in": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz",
+ "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=",
+ "dev": true
+ },
+ "forever-agent": {
+ "version": "0.6.1",
+ "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz",
+ "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=",
+ "dev": true
+ },
+ "form-data": {
+ "version": "2.3.3",
+ "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz",
+ "integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==",
+ "dev": true,
+ "requires": {
+ "asynckit": "^0.4.0",
+ "combined-stream": "^1.0.6",
+ "mime-types": "^2.1.12"
+ }
+ },
+ "fragment-cache": {
+ "version": "0.2.1",
+ "resolved": "https://registry.npmjs.org/fragment-cache/-/fragment-cache-0.2.1.tgz",
+ "integrity": "sha1-QpD60n8T6Jvn8zeZxrxaCr//DRk=",
+ "dev": true,
+ "requires": {
+ "map-cache": "^0.2.2"
+ }
+ },
+ "fs-minipass": {
+ "version": "1.2.7",
+ "resolved": "https://registry.npmjs.org/fs-minipass/-/fs-minipass-1.2.7.tgz",
+ "integrity": "sha512-GWSSJGFy4e9GUeCcbIkED+bgAoFyj7XF1mV8rma3QW4NIqX9Kyx79N/PF61H5udOV3aY1IaMLs6pGbH71nlCTA==",
+ "dev": true,
+ "requires": {
+ "minipass": "^2.6.0"
+ }
+ },
+ "fs.realpath": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz",
+ "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=",
+ "dev": true
+ },
+ "fsevents": {
+ "version": "2.1.3",
+ "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.1.3.tgz",
+ "integrity": "sha512-Auw9a4AxqWpa9GUfj370BMPzzyncfBABW8Mab7BGWBYDj4Isgq+cDKtx0i6u9jcX9pQDnswsaaOTgTmA5pEjuQ==",
+ "dev": true,
+ "optional": true
+ },
+ "gauge": {
+ "version": "2.7.4",
+ "resolved": "https://registry.npmjs.org/gauge/-/gauge-2.7.4.tgz",
+ "integrity": "sha1-LANAXHU4w51+s3sxcCLjJfsBi/c=",
+ "dev": true,
+ "requires": {
+ "aproba": "^1.0.3",
+ "console-control-strings": "^1.0.0",
+ "has-unicode": "^2.0.0",
+ "object-assign": "^4.1.0",
+ "signal-exit": "^3.0.0",
+ "string-width": "^1.0.1",
+ "strip-ansi": "^3.0.1",
+ "wide-align": "^1.1.0"
+ }
+ },
+ "gensync": {
+ "version": "1.0.0-beta.1",
+ "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.1.tgz",
+ "integrity": "sha512-r8EC6NO1sngH/zdD9fiRDLdcgnbayXah+mLgManTaIZJqEC1MZstmnox8KpnI2/fxQwrp5OpCOYWLp4rBl4Jcg==",
+ "dev": true
+ },
+ "get-caller-file": {
+ "version": "2.0.5",
+ "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz",
+ "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==",
+ "dev": true
+ },
+ "get-package-type": {
+ "version": "0.1.0",
+ "resolved": "https://registry.npmjs.org/get-package-type/-/get-package-type-0.1.0.tgz",
+ "integrity": "sha512-pjzuKtY64GYfWizNAJ0fr9VqttZkNiK2iS430LtIHzjBEr6bX8Am2zm4sW4Ro5wjWW5cAlRL1qAMTcXbjNAO2Q==",
+ "dev": true
+ },
+ "get-stream": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz",
+ "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==",
+ "dev": true,
+ "requires": {
+ "pump": "^3.0.0"
+ }
+ },
+ "get-value": {
+ "version": "2.0.6",
+ "resolved": "https://registry.npmjs.org/get-value/-/get-value-2.0.6.tgz",
+ "integrity": "sha1-3BXKHGcjh8p2vTesCjlbogQqLCg=",
+ "dev": true
+ },
+ "getpass": {
+ "version": "0.1.7",
+ "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz",
+ "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=",
+ "dev": true,
+ "requires": {
+ "assert-plus": "^1.0.0"
+ }
+ },
+ "glob": {
+ "version": "7.1.6",
+ "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz",
+ "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==",
+ "dev": true,
+ "requires": {
+ "fs.realpath": "^1.0.0",
+ "inflight": "^1.0.4",
+ "inherits": "2",
+ "minimatch": "^3.0.4",
+ "once": "^1.3.0",
+ "path-is-absolute": "^1.0.0"
+ }
+ },
+ "globals": {
+ "version": "11.12.0",
+ "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz",
+ "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==",
+ "dev": true
+ },
+ "graceful-fs": {
+ "version": "4.2.4",
+ "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.4.tgz",
+ "integrity": "sha512-WjKPNJF79dtJAVniUlGGWHYGz2jWxT6VhN/4m1NdkbZ2nOsEF+cI1Edgql5zCRhs/VsQYRvrXctxktVXZUkixw==",
+ "dev": true
+ },
+ "growly": {
+ "version": "1.3.0",
+ "resolved": "https://registry.npmjs.org/growly/-/growly-1.3.0.tgz",
+ "integrity": "sha1-8QdIy+dq+WS3yWyTxrzCivEgwIE=",
+ "dev": true,
+ "optional": true
+ },
+ "har-schema": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz",
+ "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=",
+ "dev": true
+ },
+ "har-validator": {
+ "version": "5.1.3",
+ "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.1.3.tgz",
+ "integrity": "sha512-sNvOCzEQNr/qrvJgc3UG/kD4QtlHycrzwS+6mfTrrSq97BvaYcPZZI1ZSqGSPR73Cxn4LKTD4PttRwfU7jWq5g==",
+ "dev": true,
+ "requires": {
+ "ajv": "^6.5.5",
+ "har-schema": "^2.0.0"
+ }
+ },
+ "has-flag": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
+ "dev": true
+ },
+ "has-unicode": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz",
+ "integrity": "sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk=",
+ "dev": true
+ },
+ "has-value": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/has-value/-/has-value-1.0.0.tgz",
+ "integrity": "sha1-GLKB2lhbHFxR3vJMkw7SmgvmsXc=",
+ "dev": true,
+ "requires": {
+ "get-value": "^2.0.6",
+ "has-values": "^1.0.0",
+ "isobject": "^3.0.0"
+ }
+ },
+ "has-values": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/has-values/-/has-values-1.0.0.tgz",
+ "integrity": "sha1-lbC2P+whRmGab+V/51Yo1aOe/k8=",
+ "dev": true,
+ "requires": {
+ "is-number": "^3.0.0",
+ "kind-of": "^4.0.0"
+ },
+ "dependencies": {
+ "is-number": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz",
+ "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=",
+ "dev": true,
+ "requires": {
+ "kind-of": "^3.0.2"
+ },
+ "dependencies": {
+ "kind-of": {
+ "version": "3.2.2",
+ "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
+ "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
+ "dev": true,
+ "requires": {
+ "is-buffer": "^1.1.5"
+ }
+ }
+ }
+ },
+ "kind-of": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-4.0.0.tgz",
+ "integrity": "sha1-IIE989cSkosgc3hpGkUGb65y3Vc=",
+ "dev": true,
+ "requires": {
+ "is-buffer": "^1.1.5"
+ }
+ }
+ }
+ },
+ "hosted-git-info": {
+ "version": "2.8.8",
+ "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.8.tgz",
+ "integrity": "sha512-f/wzC2QaWBs7t9IYqB4T3sR1xviIViXJRJTWBlx2Gf3g0Xi5vI7Yy4koXQ1c9OYDGHN9sBy1DQ2AB8fqZBWhUg==",
+ "dev": true
+ },
+ "html-encoding-sniffer": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/html-encoding-sniffer/-/html-encoding-sniffer-2.0.1.tgz",
+ "integrity": "sha512-D5JbOMBIR/TVZkubHT+OyT2705QvogUW4IBn6nHd756OwieSF9aDYFj4dv6HHEVGYbHaLETa3WggZYWWMyy3ZQ==",
+ "dev": true,
+ "requires": {
+ "whatwg-encoding": "^1.0.5"
+ }
+ },
+ "html-escaper": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz",
+ "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==",
+ "dev": true
+ },
+ "http-signature": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz",
+ "integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=",
+ "dev": true,
+ "requires": {
+ "assert-plus": "^1.0.0",
+ "jsprim": "^1.2.2",
+ "sshpk": "^1.7.0"
+ }
+ },
+ "human-signals": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-1.1.1.tgz",
+ "integrity": "sha512-SEQu7vl8KjNL2eoGBLF3+wAjpsNfA9XMlXAYj/3EdaNfAlxKthD1xjEQfGOUhllCGGJVNY34bRr6lPINhNjyZw==",
+ "dev": true
+ },
+ "iconv-lite": {
+ "version": "0.4.24",
+ "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz",
+ "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==",
+ "dev": true,
+ "requires": {
+ "safer-buffer": ">= 2.1.2 < 3"
+ }
+ },
+ "ignore-walk": {
+ "version": "3.0.3",
+ "resolved": "https://registry.npmjs.org/ignore-walk/-/ignore-walk-3.0.3.tgz",
+ "integrity": "sha512-m7o6xuOaT1aqheYHKf8W6J5pYH85ZI9w077erOzLje3JsB1gkafkAhHHY19dqjulgIZHFm32Cp5uNZgcQqdJKw==",
+ "dev": true,
+ "requires": {
+ "minimatch": "^3.0.4"
+ }
+ },
+ "import-local": {
+ "version": "3.0.2",
+ "resolved": "https://registry.npmjs.org/import-local/-/import-local-3.0.2.tgz",
+ "integrity": "sha512-vjL3+w0oulAVZ0hBHnxa/Nm5TAurf9YLQJDhqRZyqb+VKGOB6LU8t9H1Nr5CIo16vh9XfJTOoHwU0B71S557gA==",
+ "dev": true,
+ "requires": {
+ "pkg-dir": "^4.2.0",
+ "resolve-cwd": "^3.0.0"
+ }
+ },
+ "imurmurhash": {
+ "version": "0.1.4",
+ "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz",
+ "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=",
+ "dev": true
+ },
+ "inflight": {
+ "version": "1.0.6",
+ "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz",
+ "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=",
+ "dev": true,
+ "requires": {
+ "once": "^1.3.0",
+ "wrappy": "1"
+ }
+ },
+ "inherits": {
+ "version": "2.0.4",
+ "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz",
+ "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==",
+ "dev": true
+ },
+ "ini": {
+ "version": "1.3.5",
+ "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.5.tgz",
+ "integrity": "sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw==",
+ "dev": true
+ },
+ "ip-regex": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/ip-regex/-/ip-regex-2.1.0.tgz",
+ "integrity": "sha1-+ni/XS5pE8kRzp+BnuUUa7bYROk=",
+ "dev": true
+ },
+ "is-accessor-descriptor": {
+ "version": "0.1.6",
+ "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz",
+ "integrity": "sha1-qeEss66Nh2cn7u84Q/igiXtcmNY=",
+ "dev": true,
+ "requires": {
+ "kind-of": "^3.0.2"
+ },
+ "dependencies": {
+ "kind-of": {
+ "version": "3.2.2",
+ "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
+ "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
+ "dev": true,
+ "requires": {
+ "is-buffer": "^1.1.5"
+ }
+ }
+ }
+ },
+ "is-arrayish": {
+ "version": "0.2.1",
+ "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz",
+ "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=",
+ "dev": true
+ },
+ "is-buffer": {
+ "version": "1.1.6",
+ "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz",
+ "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==",
+ "dev": true
+ },
+ "is-ci": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-2.0.0.tgz",
+ "integrity": "sha512-YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w==",
+ "dev": true,
+ "requires": {
+ "ci-info": "^2.0.0"
+ }
+ },
+ "is-data-descriptor": {
+ "version": "0.1.4",
+ "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz",
+ "integrity": "sha1-C17mSDiOLIYCgueT8YVv7D8wG1Y=",
+ "dev": true,
+ "requires": {
+ "kind-of": "^3.0.2"
+ },
+ "dependencies": {
+ "kind-of": {
+ "version": "3.2.2",
+ "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
+ "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
+ "dev": true,
+ "requires": {
+ "is-buffer": "^1.1.5"
+ }
+ }
+ }
+ },
+ "is-descriptor": {
+ "version": "0.1.6",
+ "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.6.tgz",
+ "integrity": "sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg==",
+ "dev": true,
+ "requires": {
+ "is-accessor-descriptor": "^0.1.6",
+ "is-data-descriptor": "^0.1.4",
+ "kind-of": "^5.0.0"
+ },
+ "dependencies": {
+ "kind-of": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-5.1.0.tgz",
+ "integrity": "sha512-NGEErnH6F2vUuXDh+OlbcKW7/wOcfdRHaZ7VWtqCztfHri/++YKmP51OdWeGPuqCOba6kk2OTe5d02VmTB80Pw==",
+ "dev": true
+ }
+ }
+ },
+ "is-docker": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/is-docker/-/is-docker-2.0.0.tgz",
+ "integrity": "sha512-pJEdRugimx4fBMra5z2/5iRdZ63OhYV0vr0Dwm5+xtW4D1FvRkB8hamMIhnWfyJeDdyr/aa7BDyNbtG38VxgoQ==",
+ "dev": true,
+ "optional": true
+ },
+ "is-extendable": {
+ "version": "0.1.1",
+ "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz",
+ "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=",
+ "dev": true
+ },
+ "is-fullwidth-code-point": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz",
+ "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=",
+ "dev": true,
+ "requires": {
+ "number-is-nan": "^1.0.0"
+ }
+ },
+ "is-generator-fn": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/is-generator-fn/-/is-generator-fn-2.1.0.tgz",
+ "integrity": "sha512-cTIB4yPYL/Grw0EaSzASzg6bBy9gqCofvWN8okThAYIxKJZC+udlRAmGbM0XLeniEJSs8uEgHPGuHSe1XsOLSQ==",
+ "dev": true
+ },
+ "is-number": {
+ "version": "7.0.0",
+ "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz",
+ "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==",
+ "dev": true
+ },
+ "is-plain-object": {
+ "version": "2.0.4",
+ "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz",
+ "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==",
+ "dev": true,
+ "requires": {
+ "isobject": "^3.0.1"
+ }
+ },
+ "is-potential-custom-element-name": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/is-potential-custom-element-name/-/is-potential-custom-element-name-1.0.0.tgz",
+ "integrity": "sha1-DFLlS8yjkbssSUsh6GJtczbG45c=",
+ "dev": true
+ },
+ "is-stream": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz",
+ "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=",
+ "dev": true
+ },
+ "is-typedarray": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz",
+ "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=",
+ "dev": true
+ },
+ "is-windows": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.2.tgz",
+ "integrity": "sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA==",
+ "dev": true
+ },
+ "is-wsl": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/is-wsl/-/is-wsl-2.2.0.tgz",
+ "integrity": "sha512-fKzAra0rGJUUBwGBgNkHZuToZcn+TtXHpeCgmkMJMMYx1sQDYaCSyjJBSCa2nH1DGm7s3n1oBnohoVTBaN7Lww==",
+ "dev": true,
+ "optional": true,
+ "requires": {
+ "is-docker": "^2.0.0"
+ }
+ },
+ "isarray": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz",
+ "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=",
+ "dev": true
+ },
+ "isexe": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz",
+ "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=",
+ "dev": true
+ },
+ "isobject": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz",
+ "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=",
+ "dev": true
+ },
+ "isstream": {
+ "version": "0.1.2",
+ "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz",
+ "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=",
+ "dev": true
+ },
+ "istanbul-lib-coverage": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.0.0.tgz",
+ "integrity": "sha512-UiUIqxMgRDET6eR+o5HbfRYP1l0hqkWOs7vNxC/mggutCMUIhWMm8gAHb8tHlyfD3/l6rlgNA5cKdDzEAf6hEg==",
+ "dev": true
+ },
+ "istanbul-lib-instrument": {
+ "version": "4.0.3",
+ "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-4.0.3.tgz",
+ "integrity": "sha512-BXgQl9kf4WTCPCCpmFGoJkz/+uhvm7h7PFKUYxh7qarQd3ER33vHG//qaE8eN25l07YqZPpHXU9I09l/RD5aGQ==",
+ "dev": true,
+ "requires": {
+ "@babel/core": "^7.7.5",
+ "@istanbuljs/schema": "^0.1.2",
+ "istanbul-lib-coverage": "^3.0.0",
+ "semver": "^6.3.0"
+ },
+ "dependencies": {
+ "semver": {
+ "version": "6.3.0",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz",
+ "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==",
+ "dev": true
+ }
+ }
+ },
+ "istanbul-lib-report": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz",
+ "integrity": "sha512-wcdi+uAKzfiGT2abPpKZ0hSU1rGQjUQnLvtY5MpQ7QCTahD3VODhcu4wcfY1YtkGaDD5yuydOLINXsfbus9ROw==",
+ "dev": true,
+ "requires": {
+ "istanbul-lib-coverage": "^3.0.0",
+ "make-dir": "^3.0.0",
+ "supports-color": "^7.1.0"
+ }
+ },
+ "istanbul-lib-source-maps": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-4.0.0.tgz",
+ "integrity": "sha512-c16LpFRkR8vQXyHZ5nLpY35JZtzj1PQY1iZmesUbf1FZHbIupcWfjgOXBY9YHkLEQ6puz1u4Dgj6qmU/DisrZg==",
+ "dev": true,
+ "requires": {
+ "debug": "^4.1.1",
+ "istanbul-lib-coverage": "^3.0.0",
+ "source-map": "^0.6.1"
+ },
+ "dependencies": {
+ "debug": {
+ "version": "4.1.1",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz",
+ "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==",
+ "dev": true,
+ "requires": {
+ "ms": "^2.1.1"
+ }
+ }
+ }
+ },
+ "istanbul-reports": {
+ "version": "3.0.2",
+ "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.0.2.tgz",
+ "integrity": "sha512-9tZvz7AiR3PEDNGiV9vIouQ/EAcqMXFmkcA1CDFTwOB98OZVDL0PH9glHotf5Ugp6GCOTypfzGWI/OqjWNCRUw==",
+ "dev": true,
+ "requires": {
+ "html-escaper": "^2.0.0",
+ "istanbul-lib-report": "^3.0.0"
+ }
+ },
+ "jest": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/jest/-/jest-26.1.0.tgz",
+ "integrity": "sha512-LIti8jppw5BcQvmNJe4w2g1N/3V68HUfAv9zDVm7v+VAtQulGhH0LnmmiVkbNE4M4I43Bj2fXPiBGKt26k9tHw==",
+ "dev": true,
+ "requires": {
+ "@jest/core": "^26.1.0",
+ "import-local": "^3.0.2",
+ "jest-cli": "^26.1.0"
+ },
+ "dependencies": {
+ "@jest/types": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.1.0.tgz",
+ "integrity": "sha512-GXigDDsp6ZlNMhXQDeuy/iYCDsRIHJabWtDzvnn36+aqFfG14JmFV0e/iXxY4SP9vbXSiPNOWdehU5MeqrYHBQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0"
+ }
+ },
+ "chalk": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+ "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ },
+ "jest-cli": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/jest-cli/-/jest-cli-26.1.0.tgz",
+ "integrity": "sha512-Imumvjgi3rU7stq6SJ1JUEMaV5aAgJYXIs0jPqdUnF47N/Tk83EXfmtvNKQ+SnFVI6t6mDOvfM3aA9Sg6kQPSw==",
+ "dev": true,
+ "requires": {
+ "@jest/core": "^26.1.0",
+ "@jest/test-result": "^26.1.0",
+ "@jest/types": "^26.1.0",
+ "chalk": "^4.0.0",
+ "exit": "^0.1.2",
+ "graceful-fs": "^4.2.4",
+ "import-local": "^3.0.2",
+ "is-ci": "^2.0.0",
+ "jest-config": "^26.1.0",
+ "jest-util": "^26.1.0",
+ "jest-validate": "^26.1.0",
+ "prompts": "^2.0.1",
+ "yargs": "^15.3.1"
+ }
+ }
+ }
+ },
+ "jest-changed-files": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/jest-changed-files/-/jest-changed-files-26.1.0.tgz",
+ "integrity": "sha512-HS5MIJp3B8t0NRKGMCZkcDUZo36mVRvrDETl81aqljT1S9tqiHRSpyoOvWg9ZilzZG9TDisDNaN1IXm54fLRZw==",
+ "dev": true,
+ "requires": {
+ "@jest/types": "^26.1.0",
+ "execa": "^4.0.0",
+ "throat": "^5.0.0"
+ },
+ "dependencies": {
+ "@jest/types": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.1.0.tgz",
+ "integrity": "sha512-GXigDDsp6ZlNMhXQDeuy/iYCDsRIHJabWtDzvnn36+aqFfG14JmFV0e/iXxY4SP9vbXSiPNOWdehU5MeqrYHBQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0"
+ }
+ },
+ "chalk": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+ "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ },
+ "cross-spawn": {
+ "version": "7.0.3",
+ "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz",
+ "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==",
+ "dev": true,
+ "requires": {
+ "path-key": "^3.1.0",
+ "shebang-command": "^2.0.0",
+ "which": "^2.0.1"
+ }
+ },
+ "execa": {
+ "version": "4.0.3",
+ "resolved": "https://registry.npmjs.org/execa/-/execa-4.0.3.tgz",
+ "integrity": "sha512-WFDXGHckXPWZX19t1kCsXzOpqX9LWYNqn4C+HqZlk/V0imTkzJZqf87ZBhvpHaftERYknpk0fjSylnXVlVgI0A==",
+ "dev": true,
+ "requires": {
+ "cross-spawn": "^7.0.0",
+ "get-stream": "^5.0.0",
+ "human-signals": "^1.1.1",
+ "is-stream": "^2.0.0",
+ "merge-stream": "^2.0.0",
+ "npm-run-path": "^4.0.0",
+ "onetime": "^5.1.0",
+ "signal-exit": "^3.0.2",
+ "strip-final-newline": "^2.0.0"
+ }
+ },
+ "get-stream": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.1.0.tgz",
+ "integrity": "sha512-EXr1FOzrzTfGeL0gQdeFEvOMm2mzMOglyiOXSTpPC+iAjAKftbr3jpCMWynogwYnM+eSj9sHGc6wjIcDvYiygw==",
+ "dev": true,
+ "requires": {
+ "pump": "^3.0.0"
+ }
+ },
+ "is-stream": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.0.tgz",
+ "integrity": "sha512-XCoy+WlUr7d1+Z8GgSuXmpuUFC9fOhRXglJMx+dwLKTkL44Cjd4W1Z5P+BQZpr+cR93aGP4S/s7Ftw6Nd/kiEw==",
+ "dev": true
+ },
+ "npm-run-path": {
+ "version": "4.0.1",
+ "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz",
+ "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==",
+ "dev": true,
+ "requires": {
+ "path-key": "^3.0.0"
+ }
+ },
+ "path-key": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz",
+ "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==",
+ "dev": true
+ },
+ "shebang-command": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz",
+ "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==",
+ "dev": true,
+ "requires": {
+ "shebang-regex": "^3.0.0"
+ }
+ },
+ "shebang-regex": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz",
+ "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==",
+ "dev": true
+ }
+ }
+ },
+ "jest-config": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/jest-config/-/jest-config-26.1.0.tgz",
+ "integrity": "sha512-ONTGeoMbAwGCdq4WuKkMcdMoyfs5CLzHEkzFOlVvcDXufZSaIWh/OXMLa2fwKXiOaFcqEw8qFr4VOKJQfn4CVw==",
+ "dev": true,
+ "requires": {
+ "@babel/core": "^7.1.0",
+ "@jest/test-sequencer": "^26.1.0",
+ "@jest/types": "^26.1.0",
+ "babel-jest": "^26.1.0",
+ "chalk": "^4.0.0",
+ "deepmerge": "^4.2.2",
+ "glob": "^7.1.1",
+ "graceful-fs": "^4.2.4",
+ "jest-environment-jsdom": "^26.1.0",
+ "jest-environment-node": "^26.1.0",
+ "jest-get-type": "^26.0.0",
+ "jest-jasmine2": "^26.1.0",
+ "jest-regex-util": "^26.0.0",
+ "jest-resolve": "^26.1.0",
+ "jest-util": "^26.1.0",
+ "jest-validate": "^26.1.0",
+ "micromatch": "^4.0.2",
+ "pretty-format": "^26.1.0"
+ },
+ "dependencies": {
+ "@jest/types": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.1.0.tgz",
+ "integrity": "sha512-GXigDDsp6ZlNMhXQDeuy/iYCDsRIHJabWtDzvnn36+aqFfG14JmFV0e/iXxY4SP9vbXSiPNOWdehU5MeqrYHBQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0"
+ }
+ },
+ "chalk": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+ "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ },
+ "jest-get-type": {
+ "version": "26.0.0",
+ "resolved": "https://registry.npmjs.org/jest-get-type/-/jest-get-type-26.0.0.tgz",
+ "integrity": "sha512-zRc1OAPnnws1EVfykXOj19zo2EMw5Hi6HLbFCSjpuJiXtOWAYIjNsHVSbpQ8bDX7L5BGYGI8m+HmKdjHYFF0kg==",
+ "dev": true
+ },
+ "pretty-format": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-26.1.0.tgz",
+ "integrity": "sha512-GmeO1PEYdM+non4BKCj+XsPJjFOJIPnsLewqhDVoqY1xo0yNmDas7tC2XwpMrRAHR3MaE2hPo37deX5OisJ2Wg==",
+ "dev": true,
+ "requires": {
+ "@jest/types": "^26.1.0",
+ "ansi-regex": "^5.0.0",
+ "ansi-styles": "^4.0.0",
+ "react-is": "^16.12.0"
+ }
+ }
+ }
+ },
+ "jest-diff": {
+ "version": "25.5.0",
+ "resolved": "https://registry.npmjs.org/jest-diff/-/jest-diff-25.5.0.tgz",
+ "integrity": "sha512-z1kygetuPiREYdNIumRpAHY6RXiGmp70YHptjdaxTWGmA085W3iCnXNx0DhflK3vwrKmrRWyY1wUpkPMVxMK7A==",
+ "dev": true,
+ "requires": {
+ "chalk": "^3.0.0",
+ "diff-sequences": "^25.2.6",
+ "jest-get-type": "^25.2.6",
+ "pretty-format": "^25.5.0"
+ }
+ },
+ "jest-docblock": {
+ "version": "26.0.0",
+ "resolved": "https://registry.npmjs.org/jest-docblock/-/jest-docblock-26.0.0.tgz",
+ "integrity": "sha512-RDZ4Iz3QbtRWycd8bUEPxQsTlYazfYn/h5R65Fc6gOfwozFhoImx+affzky/FFBuqISPTqjXomoIGJVKBWoo0w==",
+ "dev": true,
+ "requires": {
+ "detect-newline": "^3.0.0"
+ }
+ },
+ "jest-each": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/jest-each/-/jest-each-26.1.0.tgz",
+ "integrity": "sha512-lYiSo4Igr81q6QRsVQq9LIkJW0hZcKxkIkHzNeTMPENYYDw/W/Raq28iJ0sLlNFYz2qxxeLnc5K2gQoFYlu2bA==",
+ "dev": true,
+ "requires": {
+ "@jest/types": "^26.1.0",
+ "chalk": "^4.0.0",
+ "jest-get-type": "^26.0.0",
+ "jest-util": "^26.1.0",
+ "pretty-format": "^26.1.0"
+ },
+ "dependencies": {
+ "@jest/types": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.1.0.tgz",
+ "integrity": "sha512-GXigDDsp6ZlNMhXQDeuy/iYCDsRIHJabWtDzvnn36+aqFfG14JmFV0e/iXxY4SP9vbXSiPNOWdehU5MeqrYHBQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0"
+ }
+ },
+ "chalk": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+ "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ },
+ "jest-get-type": {
+ "version": "26.0.0",
+ "resolved": "https://registry.npmjs.org/jest-get-type/-/jest-get-type-26.0.0.tgz",
+ "integrity": "sha512-zRc1OAPnnws1EVfykXOj19zo2EMw5Hi6HLbFCSjpuJiXtOWAYIjNsHVSbpQ8bDX7L5BGYGI8m+HmKdjHYFF0kg==",
+ "dev": true
+ },
+ "pretty-format": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-26.1.0.tgz",
+ "integrity": "sha512-GmeO1PEYdM+non4BKCj+XsPJjFOJIPnsLewqhDVoqY1xo0yNmDas7tC2XwpMrRAHR3MaE2hPo37deX5OisJ2Wg==",
+ "dev": true,
+ "requires": {
+ "@jest/types": "^26.1.0",
+ "ansi-regex": "^5.0.0",
+ "ansi-styles": "^4.0.0",
+ "react-is": "^16.12.0"
+ }
+ }
+ }
+ },
+ "jest-environment-jsdom": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/jest-environment-jsdom/-/jest-environment-jsdom-26.1.0.tgz",
+ "integrity": "sha512-dWfiJ+spunVAwzXbdVqPH1LbuJW/kDL+FyqgA5YzquisHqTi0g9hquKif9xKm7c1bKBj6wbmJuDkeMCnxZEpUw==",
+ "dev": true,
+ "requires": {
+ "@jest/environment": "^26.1.0",
+ "@jest/fake-timers": "^26.1.0",
+ "@jest/types": "^26.1.0",
+ "jest-mock": "^26.1.0",
+ "jest-util": "^26.1.0",
+ "jsdom": "^16.2.2"
+ },
+ "dependencies": {
+ "@jest/types": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.1.0.tgz",
+ "integrity": "sha512-GXigDDsp6ZlNMhXQDeuy/iYCDsRIHJabWtDzvnn36+aqFfG14JmFV0e/iXxY4SP9vbXSiPNOWdehU5MeqrYHBQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0"
+ }
+ },
+ "chalk": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+ "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ }
+ }
+ },
+ "jest-environment-node": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/jest-environment-node/-/jest-environment-node-26.1.0.tgz",
+ "integrity": "sha512-DNm5x1aQH0iRAe9UYAkZenuzuJ69VKzDCAYISFHQ5i9e+2Tbeu2ONGY7YStubCLH8a1wdKBgqScYw85+ySxqxg==",
+ "dev": true,
+ "requires": {
+ "@jest/environment": "^26.1.0",
+ "@jest/fake-timers": "^26.1.0",
+ "@jest/types": "^26.1.0",
+ "jest-mock": "^26.1.0",
+ "jest-util": "^26.1.0"
+ },
+ "dependencies": {
+ "@jest/types": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.1.0.tgz",
+ "integrity": "sha512-GXigDDsp6ZlNMhXQDeuy/iYCDsRIHJabWtDzvnn36+aqFfG14JmFV0e/iXxY4SP9vbXSiPNOWdehU5MeqrYHBQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0"
+ }
+ },
+ "chalk": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+ "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ }
+ }
+ },
+ "jest-get-type": {
+ "version": "25.2.6",
+ "resolved": "https://registry.npmjs.org/jest-get-type/-/jest-get-type-25.2.6.tgz",
+ "integrity": "sha512-DxjtyzOHjObRM+sM1knti6or+eOgcGU4xVSb2HNP1TqO4ahsT+rqZg+nyqHWJSvWgKC5cG3QjGFBqxLghiF/Ig==",
+ "dev": true
+ },
+ "jest-haste-map": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/jest-haste-map/-/jest-haste-map-26.1.0.tgz",
+ "integrity": "sha512-WeBS54xCIz9twzkEdm6+vJBXgRBQfdbbXD0dk8lJh7gLihopABlJmIQFdWSDDtuDe4PRiObsjZSUjbJ1uhWEpA==",
+ "dev": true,
+ "requires": {
+ "@jest/types": "^26.1.0",
+ "@types/graceful-fs": "^4.1.2",
+ "anymatch": "^3.0.3",
+ "fb-watchman": "^2.0.0",
+ "fsevents": "^2.1.2",
+ "graceful-fs": "^4.2.4",
+ "jest-serializer": "^26.1.0",
+ "jest-util": "^26.1.0",
+ "jest-worker": "^26.1.0",
+ "micromatch": "^4.0.2",
+ "sane": "^4.0.3",
+ "walker": "^1.0.7",
+ "which": "^2.0.2"
+ },
+ "dependencies": {
+ "@jest/types": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.1.0.tgz",
+ "integrity": "sha512-GXigDDsp6ZlNMhXQDeuy/iYCDsRIHJabWtDzvnn36+aqFfG14JmFV0e/iXxY4SP9vbXSiPNOWdehU5MeqrYHBQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0"
+ }
+ },
+ "chalk": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+ "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ }
+ }
+ },
+ "jest-jasmine2": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/jest-jasmine2/-/jest-jasmine2-26.1.0.tgz",
+ "integrity": "sha512-1IPtoDKOAG+MeBrKvvuxxGPJb35MTTRSDglNdWWCndCB3TIVzbLThRBkwH9P081vXLgiJHZY8Bz3yzFS803xqQ==",
+ "dev": true,
+ "requires": {
+ "@babel/traverse": "^7.1.0",
+ "@jest/environment": "^26.1.0",
+ "@jest/source-map": "^26.1.0",
+ "@jest/test-result": "^26.1.0",
+ "@jest/types": "^26.1.0",
+ "chalk": "^4.0.0",
+ "co": "^4.6.0",
+ "expect": "^26.1.0",
+ "is-generator-fn": "^2.0.0",
+ "jest-each": "^26.1.0",
+ "jest-matcher-utils": "^26.1.0",
+ "jest-message-util": "^26.1.0",
+ "jest-runtime": "^26.1.0",
+ "jest-snapshot": "^26.1.0",
+ "jest-util": "^26.1.0",
+ "pretty-format": "^26.1.0",
+ "throat": "^5.0.0"
+ },
+ "dependencies": {
+ "@jest/types": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.1.0.tgz",
+ "integrity": "sha512-GXigDDsp6ZlNMhXQDeuy/iYCDsRIHJabWtDzvnn36+aqFfG14JmFV0e/iXxY4SP9vbXSiPNOWdehU5MeqrYHBQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0"
+ }
+ },
+ "chalk": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+ "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ },
+ "pretty-format": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-26.1.0.tgz",
+ "integrity": "sha512-GmeO1PEYdM+non4BKCj+XsPJjFOJIPnsLewqhDVoqY1xo0yNmDas7tC2XwpMrRAHR3MaE2hPo37deX5OisJ2Wg==",
+ "dev": true,
+ "requires": {
+ "@jest/types": "^26.1.0",
+ "ansi-regex": "^5.0.0",
+ "ansi-styles": "^4.0.0",
+ "react-is": "^16.12.0"
+ }
+ }
+ }
+ },
+ "jest-leak-detector": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/jest-leak-detector/-/jest-leak-detector-26.1.0.tgz",
+ "integrity": "sha512-dsMnKF+4BVOZwvQDlgn3MG+Ns4JuLv8jNvXH56bgqrrboyCbI1rQg6EI5rs+8IYagVcfVP2yZFKfWNZy0rK0Hw==",
+ "dev": true,
+ "requires": {
+ "jest-get-type": "^26.0.0",
+ "pretty-format": "^26.1.0"
+ },
+ "dependencies": {
+ "@jest/types": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.1.0.tgz",
+ "integrity": "sha512-GXigDDsp6ZlNMhXQDeuy/iYCDsRIHJabWtDzvnn36+aqFfG14JmFV0e/iXxY4SP9vbXSiPNOWdehU5MeqrYHBQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0"
+ }
+ },
+ "chalk": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+ "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ },
+ "jest-get-type": {
+ "version": "26.0.0",
+ "resolved": "https://registry.npmjs.org/jest-get-type/-/jest-get-type-26.0.0.tgz",
+ "integrity": "sha512-zRc1OAPnnws1EVfykXOj19zo2EMw5Hi6HLbFCSjpuJiXtOWAYIjNsHVSbpQ8bDX7L5BGYGI8m+HmKdjHYFF0kg==",
+ "dev": true
+ },
+ "pretty-format": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-26.1.0.tgz",
+ "integrity": "sha512-GmeO1PEYdM+non4BKCj+XsPJjFOJIPnsLewqhDVoqY1xo0yNmDas7tC2XwpMrRAHR3MaE2hPo37deX5OisJ2Wg==",
+ "dev": true,
+ "requires": {
+ "@jest/types": "^26.1.0",
+ "ansi-regex": "^5.0.0",
+ "ansi-styles": "^4.0.0",
+ "react-is": "^16.12.0"
+ }
+ }
+ }
+ },
+ "jest-matcher-utils": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/jest-matcher-utils/-/jest-matcher-utils-26.1.0.tgz",
+ "integrity": "sha512-PW9JtItbYvES/xLn5mYxjMd+Rk+/kIt88EfH3N7w9KeOrHWaHrdYPnVHndGbsFGRJ2d5gKtwggCvkqbFDoouQA==",
+ "dev": true,
+ "requires": {
+ "chalk": "^4.0.0",
+ "jest-diff": "^26.1.0",
+ "jest-get-type": "^26.0.0",
+ "pretty-format": "^26.1.0"
+ },
+ "dependencies": {
+ "@jest/types": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.1.0.tgz",
+ "integrity": "sha512-GXigDDsp6ZlNMhXQDeuy/iYCDsRIHJabWtDzvnn36+aqFfG14JmFV0e/iXxY4SP9vbXSiPNOWdehU5MeqrYHBQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0"
+ }
+ },
+ "chalk": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+ "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ },
+ "diff-sequences": {
+ "version": "26.0.0",
+ "resolved": "https://registry.npmjs.org/diff-sequences/-/diff-sequences-26.0.0.tgz",
+ "integrity": "sha512-JC/eHYEC3aSS0vZGjuoc4vHA0yAQTzhQQldXMeMF+JlxLGJlCO38Gma82NV9gk1jGFz8mDzUMeaKXvjRRdJ2dg==",
+ "dev": true
+ },
+ "jest-diff": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/jest-diff/-/jest-diff-26.1.0.tgz",
+ "integrity": "sha512-GZpIcom339y0OXznsEKjtkfKxNdg7bVbEofK8Q6MnevTIiR1jNhDWKhRX6X0SDXJlwn3dy59nZ1z55fLkAqPWg==",
+ "dev": true,
+ "requires": {
+ "chalk": "^4.0.0",
+ "diff-sequences": "^26.0.0",
+ "jest-get-type": "^26.0.0",
+ "pretty-format": "^26.1.0"
+ }
+ },
+ "jest-get-type": {
+ "version": "26.0.0",
+ "resolved": "https://registry.npmjs.org/jest-get-type/-/jest-get-type-26.0.0.tgz",
+ "integrity": "sha512-zRc1OAPnnws1EVfykXOj19zo2EMw5Hi6HLbFCSjpuJiXtOWAYIjNsHVSbpQ8bDX7L5BGYGI8m+HmKdjHYFF0kg==",
+ "dev": true
+ },
+ "pretty-format": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-26.1.0.tgz",
+ "integrity": "sha512-GmeO1PEYdM+non4BKCj+XsPJjFOJIPnsLewqhDVoqY1xo0yNmDas7tC2XwpMrRAHR3MaE2hPo37deX5OisJ2Wg==",
+ "dev": true,
+ "requires": {
+ "@jest/types": "^26.1.0",
+ "ansi-regex": "^5.0.0",
+ "ansi-styles": "^4.0.0",
+ "react-is": "^16.12.0"
+ }
+ }
+ }
+ },
+ "jest-message-util": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-26.1.0.tgz",
+ "integrity": "sha512-dY0+UlldiAJwNDJ08SF0HdF32g9PkbF2NRK/+2iMPU40O6q+iSn1lgog/u0UH8ksWoPv0+gNq8cjhYO2MFtT0g==",
+ "dev": true,
+ "requires": {
+ "@babel/code-frame": "^7.0.0",
+ "@jest/types": "^26.1.0",
+ "@types/stack-utils": "^1.0.1",
+ "chalk": "^4.0.0",
+ "graceful-fs": "^4.2.4",
+ "micromatch": "^4.0.2",
+ "slash": "^3.0.0",
+ "stack-utils": "^2.0.2"
+ },
+ "dependencies": {
+ "@jest/types": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.1.0.tgz",
+ "integrity": "sha512-GXigDDsp6ZlNMhXQDeuy/iYCDsRIHJabWtDzvnn36+aqFfG14JmFV0e/iXxY4SP9vbXSiPNOWdehU5MeqrYHBQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0"
+ }
+ },
+ "chalk": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+ "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ }
+ }
+ },
+ "jest-mock": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-26.1.0.tgz",
+ "integrity": "sha512-1Rm8EIJ3ZFA8yCIie92UbxZWj9SuVmUGcyhLHyAhY6WI3NIct38nVcfOPWhJteqSn8V8e3xOMha9Ojfazfpovw==",
+ "dev": true,
+ "requires": {
+ "@jest/types": "^26.1.0"
+ },
+ "dependencies": {
+ "@jest/types": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.1.0.tgz",
+ "integrity": "sha512-GXigDDsp6ZlNMhXQDeuy/iYCDsRIHJabWtDzvnn36+aqFfG14JmFV0e/iXxY4SP9vbXSiPNOWdehU5MeqrYHBQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0"
+ }
+ },
+ "chalk": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+ "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ }
+ }
+ },
+ "jest-pnp-resolver": {
+ "version": "1.2.2",
+ "resolved": "https://registry.npmjs.org/jest-pnp-resolver/-/jest-pnp-resolver-1.2.2.tgz",
+ "integrity": "sha512-olV41bKSMm8BdnuMsewT4jqlZ8+3TCARAXjZGT9jcoSnrfUnRCqnMoF9XEeoWjbzObpqF9dRhHQj0Xb9QdF6/w==",
+ "dev": true
+ },
+ "jest-regex-util": {
+ "version": "26.0.0",
+ "resolved": "https://registry.npmjs.org/jest-regex-util/-/jest-regex-util-26.0.0.tgz",
+ "integrity": "sha512-Gv3ZIs/nA48/Zvjrl34bf+oD76JHiGDUxNOVgUjh3j890sblXryjY4rss71fPtD/njchl6PSE2hIhvyWa1eT0A==",
+ "dev": true
+ },
+ "jest-resolve": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/jest-resolve/-/jest-resolve-26.1.0.tgz",
+ "integrity": "sha512-KsY1JV9FeVgEmwIISbZZN83RNGJ1CC+XUCikf/ZWJBX/tO4a4NvA21YixokhdR9UnmPKKAC4LafVixJBrwlmfg==",
+ "dev": true,
+ "requires": {
+ "@jest/types": "^26.1.0",
+ "chalk": "^4.0.0",
+ "graceful-fs": "^4.2.4",
+ "jest-pnp-resolver": "^1.2.1",
+ "jest-util": "^26.1.0",
+ "read-pkg-up": "^7.0.1",
+ "resolve": "^1.17.0",
+ "slash": "^3.0.0"
+ },
+ "dependencies": {
+ "@jest/types": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.1.0.tgz",
+ "integrity": "sha512-GXigDDsp6ZlNMhXQDeuy/iYCDsRIHJabWtDzvnn36+aqFfG14JmFV0e/iXxY4SP9vbXSiPNOWdehU5MeqrYHBQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0"
+ }
+ },
+ "chalk": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+ "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ }
+ }
+ },
+ "jest-resolve-dependencies": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/jest-resolve-dependencies/-/jest-resolve-dependencies-26.1.0.tgz",
+ "integrity": "sha512-fQVEPHHQ1JjHRDxzlLU/buuQ9om+hqW6Vo928aa4b4yvq4ZHBtRSDsLdKQLuCqn5CkTVpYZ7ARh2fbA8WkRE6g==",
+ "dev": true,
+ "requires": {
+ "@jest/types": "^26.1.0",
+ "jest-regex-util": "^26.0.0",
+ "jest-snapshot": "^26.1.0"
+ },
+ "dependencies": {
+ "@jest/types": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.1.0.tgz",
+ "integrity": "sha512-GXigDDsp6ZlNMhXQDeuy/iYCDsRIHJabWtDzvnn36+aqFfG14JmFV0e/iXxY4SP9vbXSiPNOWdehU5MeqrYHBQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0"
+ }
+ },
+ "chalk": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+ "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ }
+ }
+ },
+ "jest-runner": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/jest-runner/-/jest-runner-26.1.0.tgz",
+ "integrity": "sha512-elvP7y0fVDREnfqit0zAxiXkDRSw6dgCkzPCf1XvIMnSDZ8yogmSKJf192dpOgnUVykmQXwYYJnCx641uLTgcw==",
+ "dev": true,
+ "requires": {
+ "@jest/console": "^26.1.0",
+ "@jest/environment": "^26.1.0",
+ "@jest/test-result": "^26.1.0",
+ "@jest/types": "^26.1.0",
+ "chalk": "^4.0.0",
+ "exit": "^0.1.2",
+ "graceful-fs": "^4.2.4",
+ "jest-config": "^26.1.0",
+ "jest-docblock": "^26.0.0",
+ "jest-haste-map": "^26.1.0",
+ "jest-jasmine2": "^26.1.0",
+ "jest-leak-detector": "^26.1.0",
+ "jest-message-util": "^26.1.0",
+ "jest-resolve": "^26.1.0",
+ "jest-runtime": "^26.1.0",
+ "jest-util": "^26.1.0",
+ "jest-worker": "^26.1.0",
+ "source-map-support": "^0.5.6",
+ "throat": "^5.0.0"
+ },
+ "dependencies": {
+ "@jest/types": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.1.0.tgz",
+ "integrity": "sha512-GXigDDsp6ZlNMhXQDeuy/iYCDsRIHJabWtDzvnn36+aqFfG14JmFV0e/iXxY4SP9vbXSiPNOWdehU5MeqrYHBQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0"
+ }
+ },
+ "chalk": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+ "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ }
+ }
+ },
+ "jest-runtime": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/jest-runtime/-/jest-runtime-26.1.0.tgz",
+ "integrity": "sha512-1qiYN+EZLmG1QV2wdEBRf+Ci8i3VSfIYLF02U18PiUDrMbhfpN/EAMMkJtT02jgJUoaEOpHAIXG6zS3QRMzRmA==",
+ "dev": true,
+ "requires": {
+ "@jest/console": "^26.1.0",
+ "@jest/environment": "^26.1.0",
+ "@jest/fake-timers": "^26.1.0",
+ "@jest/globals": "^26.1.0",
+ "@jest/source-map": "^26.1.0",
+ "@jest/test-result": "^26.1.0",
+ "@jest/transform": "^26.1.0",
+ "@jest/types": "^26.1.0",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0",
+ "collect-v8-coverage": "^1.0.0",
+ "exit": "^0.1.2",
+ "glob": "^7.1.3",
+ "graceful-fs": "^4.2.4",
+ "jest-config": "^26.1.0",
+ "jest-haste-map": "^26.1.0",
+ "jest-message-util": "^26.1.0",
+ "jest-mock": "^26.1.0",
+ "jest-regex-util": "^26.0.0",
+ "jest-resolve": "^26.1.0",
+ "jest-snapshot": "^26.1.0",
+ "jest-util": "^26.1.0",
+ "jest-validate": "^26.1.0",
+ "slash": "^3.0.0",
+ "strip-bom": "^4.0.0",
+ "yargs": "^15.3.1"
+ },
+ "dependencies": {
+ "@jest/types": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.1.0.tgz",
+ "integrity": "sha512-GXigDDsp6ZlNMhXQDeuy/iYCDsRIHJabWtDzvnn36+aqFfG14JmFV0e/iXxY4SP9vbXSiPNOWdehU5MeqrYHBQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0"
+ }
+ },
+ "chalk": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+ "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ }
+ }
+ },
+ "jest-serializer": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/jest-serializer/-/jest-serializer-26.1.0.tgz",
+ "integrity": "sha512-eqZOQG/0+MHmr25b2Z86g7+Kzd5dG9dhCiUoyUNJPgiqi38DqbDEOlHcNijyfZoj74soGBohKBZuJFS18YTJ5w==",
+ "dev": true,
+ "requires": {
+ "graceful-fs": "^4.2.4"
+ }
+ },
+ "jest-snapshot": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/jest-snapshot/-/jest-snapshot-26.1.0.tgz",
+ "integrity": "sha512-YhSbU7eMTVQO/iRbNs8j0mKRxGp4plo7sJ3GzOQ0IYjvsBiwg0T1o0zGQAYepza7lYHuPTrG5J2yDd0CE2YxSw==",
+ "dev": true,
+ "requires": {
+ "@babel/types": "^7.0.0",
+ "@jest/types": "^26.1.0",
+ "@types/prettier": "^2.0.0",
+ "chalk": "^4.0.0",
+ "expect": "^26.1.0",
+ "graceful-fs": "^4.2.4",
+ "jest-diff": "^26.1.0",
+ "jest-get-type": "^26.0.0",
+ "jest-haste-map": "^26.1.0",
+ "jest-matcher-utils": "^26.1.0",
+ "jest-message-util": "^26.1.0",
+ "jest-resolve": "^26.1.0",
+ "natural-compare": "^1.4.0",
+ "pretty-format": "^26.1.0",
+ "semver": "^7.3.2"
+ },
+ "dependencies": {
+ "@jest/types": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.1.0.tgz",
+ "integrity": "sha512-GXigDDsp6ZlNMhXQDeuy/iYCDsRIHJabWtDzvnn36+aqFfG14JmFV0e/iXxY4SP9vbXSiPNOWdehU5MeqrYHBQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0"
+ }
+ },
+ "chalk": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+ "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ },
+ "diff-sequences": {
+ "version": "26.0.0",
+ "resolved": "https://registry.npmjs.org/diff-sequences/-/diff-sequences-26.0.0.tgz",
+ "integrity": "sha512-JC/eHYEC3aSS0vZGjuoc4vHA0yAQTzhQQldXMeMF+JlxLGJlCO38Gma82NV9gk1jGFz8mDzUMeaKXvjRRdJ2dg==",
+ "dev": true
+ },
+ "jest-diff": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/jest-diff/-/jest-diff-26.1.0.tgz",
+ "integrity": "sha512-GZpIcom339y0OXznsEKjtkfKxNdg7bVbEofK8Q6MnevTIiR1jNhDWKhRX6X0SDXJlwn3dy59nZ1z55fLkAqPWg==",
+ "dev": true,
+ "requires": {
+ "chalk": "^4.0.0",
+ "diff-sequences": "^26.0.0",
+ "jest-get-type": "^26.0.0",
+ "pretty-format": "^26.1.0"
+ }
+ },
+ "jest-get-type": {
+ "version": "26.0.0",
+ "resolved": "https://registry.npmjs.org/jest-get-type/-/jest-get-type-26.0.0.tgz",
+ "integrity": "sha512-zRc1OAPnnws1EVfykXOj19zo2EMw5Hi6HLbFCSjpuJiXtOWAYIjNsHVSbpQ8bDX7L5BGYGI8m+HmKdjHYFF0kg==",
+ "dev": true
+ },
+ "pretty-format": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-26.1.0.tgz",
+ "integrity": "sha512-GmeO1PEYdM+non4BKCj+XsPJjFOJIPnsLewqhDVoqY1xo0yNmDas7tC2XwpMrRAHR3MaE2hPo37deX5OisJ2Wg==",
+ "dev": true,
+ "requires": {
+ "@jest/types": "^26.1.0",
+ "ansi-regex": "^5.0.0",
+ "ansi-styles": "^4.0.0",
+ "react-is": "^16.12.0"
+ }
+ },
+ "semver": {
+ "version": "7.3.2",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.2.tgz",
+ "integrity": "sha512-OrOb32TeeambH6UrhtShmF7CRDqhL6/5XpPNp2DuRH6+9QLw/orhp72j87v8Qa1ScDkvrrBNpZcDejAirJmfXQ==",
+ "dev": true
+ }
+ }
+ },
+ "jest-util": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-26.1.0.tgz",
+ "integrity": "sha512-rNMOwFQevljfNGvbzNQAxdmXQ+NawW/J72dmddsK0E8vgxXCMtwQ/EH0BiWEIxh0hhMcTsxwAxINt7Lh46Uzbg==",
+ "dev": true,
+ "requires": {
+ "@jest/types": "^26.1.0",
+ "chalk": "^4.0.0",
+ "graceful-fs": "^4.2.4",
+ "is-ci": "^2.0.0",
+ "micromatch": "^4.0.2"
+ },
+ "dependencies": {
+ "@jest/types": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.1.0.tgz",
+ "integrity": "sha512-GXigDDsp6ZlNMhXQDeuy/iYCDsRIHJabWtDzvnn36+aqFfG14JmFV0e/iXxY4SP9vbXSiPNOWdehU5MeqrYHBQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0"
+ }
+ },
+ "chalk": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+ "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ }
+ }
+ },
+ "jest-validate": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/jest-validate/-/jest-validate-26.1.0.tgz",
+ "integrity": "sha512-WPApOOnXsiwhZtmkDsxnpye+XLb/tUISP+H6cHjfUIXvlG+eKwP+isnivsxlHCPaO9Q5wvbhloIBkdF3qUn+Nw==",
+ "dev": true,
+ "requires": {
+ "@jest/types": "^26.1.0",
+ "camelcase": "^6.0.0",
+ "chalk": "^4.0.0",
+ "jest-get-type": "^26.0.0",
+ "leven": "^3.1.0",
+ "pretty-format": "^26.1.0"
+ },
+ "dependencies": {
+ "@jest/types": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.1.0.tgz",
+ "integrity": "sha512-GXigDDsp6ZlNMhXQDeuy/iYCDsRIHJabWtDzvnn36+aqFfG14JmFV0e/iXxY4SP9vbXSiPNOWdehU5MeqrYHBQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0"
+ }
+ },
+ "camelcase": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.0.0.tgz",
+ "integrity": "sha512-8KMDF1Vz2gzOq54ONPJS65IvTUaB1cHJ2DMM7MbPmLZljDH1qpzzLsWdiN9pHh6qvkRVDTi/07+eNGch/oLU4w==",
+ "dev": true
+ },
+ "chalk": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+ "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ },
+ "jest-get-type": {
+ "version": "26.0.0",
+ "resolved": "https://registry.npmjs.org/jest-get-type/-/jest-get-type-26.0.0.tgz",
+ "integrity": "sha512-zRc1OAPnnws1EVfykXOj19zo2EMw5Hi6HLbFCSjpuJiXtOWAYIjNsHVSbpQ8bDX7L5BGYGI8m+HmKdjHYFF0kg==",
+ "dev": true
+ },
+ "pretty-format": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-26.1.0.tgz",
+ "integrity": "sha512-GmeO1PEYdM+non4BKCj+XsPJjFOJIPnsLewqhDVoqY1xo0yNmDas7tC2XwpMrRAHR3MaE2hPo37deX5OisJ2Wg==",
+ "dev": true,
+ "requires": {
+ "@jest/types": "^26.1.0",
+ "ansi-regex": "^5.0.0",
+ "ansi-styles": "^4.0.0",
+ "react-is": "^16.12.0"
+ }
+ }
+ }
+ },
+ "jest-watcher": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/jest-watcher/-/jest-watcher-26.1.0.tgz",
+ "integrity": "sha512-ffEOhJl2EvAIki613oPsSG11usqnGUzIiK7MMX6hE4422aXOcVEG3ySCTDFLn1+LZNXGPE8tuJxhp8OBJ1pgzQ==",
+ "dev": true,
+ "requires": {
+ "@jest/test-result": "^26.1.0",
+ "@jest/types": "^26.1.0",
+ "ansi-escapes": "^4.2.1",
+ "chalk": "^4.0.0",
+ "jest-util": "^26.1.0",
+ "string-length": "^4.0.1"
+ },
+ "dependencies": {
+ "@jest/types": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/@jest/types/-/types-26.1.0.tgz",
+ "integrity": "sha512-GXigDDsp6ZlNMhXQDeuy/iYCDsRIHJabWtDzvnn36+aqFfG14JmFV0e/iXxY4SP9vbXSiPNOWdehU5MeqrYHBQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.0",
+ "@types/istanbul-reports": "^1.1.1",
+ "@types/yargs": "^15.0.0",
+ "chalk": "^4.0.0"
+ }
+ },
+ "chalk": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.0.tgz",
+ "integrity": "sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.1.0",
+ "supports-color": "^7.1.0"
+ }
+ }
+ }
+ },
+ "jest-worker": {
+ "version": "26.1.0",
+ "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-26.1.0.tgz",
+ "integrity": "sha512-Z9P5pZ6UC+kakMbNJn+tA2RdVdNX5WH1x+5UCBZ9MxIK24pjYtFt96fK+UwBTrjLYm232g1xz0L3eTh51OW+yQ==",
+ "dev": true,
+ "requires": {
+ "merge-stream": "^2.0.0",
+ "supports-color": "^7.0.0"
+ }
+ },
+ "js-tokens": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz",
+ "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==",
+ "dev": true
+ },
+ "js-yaml": {
+ "version": "3.14.0",
+ "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.0.tgz",
+ "integrity": "sha512-/4IbIeHcD9VMHFqDR/gQ7EdZdLimOvW2DdcxFjdyyZ9NsbS+ccrXqVWDtab/lRl5AlUqmpBx8EhPaWR+OtY17A==",
+ "dev": true,
+ "requires": {
+ "argparse": "^1.0.7",
+ "esprima": "^4.0.0"
+ }
+ },
+ "jsbn": {
+ "version": "0.1.1",
+ "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz",
+ "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=",
+ "dev": true
+ },
+ "jsdom": {
+ "version": "16.3.0",
+ "resolved": "https://registry.npmjs.org/jsdom/-/jsdom-16.3.0.tgz",
+ "integrity": "sha512-zggeX5UuEknpdZzv15+MS1dPYG0J/TftiiNunOeNxSl3qr8Z6cIlQpN0IdJa44z9aFxZRIVqRncvEhQ7X5DtZg==",
+ "dev": true,
+ "requires": {
+ "abab": "^2.0.3",
+ "acorn": "^7.1.1",
+ "acorn-globals": "^6.0.0",
+ "cssom": "^0.4.4",
+ "cssstyle": "^2.2.0",
+ "data-urls": "^2.0.0",
+ "decimal.js": "^10.2.0",
+ "domexception": "^2.0.1",
+ "escodegen": "^1.14.1",
+ "html-encoding-sniffer": "^2.0.1",
+ "is-potential-custom-element-name": "^1.0.0",
+ "nwsapi": "^2.2.0",
+ "parse5": "5.1.1",
+ "request": "^2.88.2",
+ "request-promise-native": "^1.0.8",
+ "saxes": "^5.0.0",
+ "symbol-tree": "^3.2.4",
+ "tough-cookie": "^3.0.1",
+ "w3c-hr-time": "^1.0.2",
+ "w3c-xmlserializer": "^2.0.0",
+ "webidl-conversions": "^6.1.0",
+ "whatwg-encoding": "^1.0.5",
+ "whatwg-mimetype": "^2.3.0",
+ "whatwg-url": "^8.0.0",
+ "ws": "^7.2.3",
+ "xml-name-validator": "^3.0.0"
+ }
+ },
+ "jsesc": {
+ "version": "2.5.2",
+ "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz",
+ "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==",
+ "dev": true
+ },
+ "json-parse-better-errors": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz",
+ "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==",
+ "dev": true
+ },
+ "json-schema": {
+ "version": "0.2.3",
+ "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz",
+ "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=",
+ "dev": true
+ },
+ "json-schema-traverse": {
+ "version": "0.4.1",
+ "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz",
+ "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==",
+ "dev": true
+ },
+ "json-stringify-safe": {
+ "version": "5.0.1",
+ "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz",
+ "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=",
+ "dev": true
+ },
+ "json5": {
+ "version": "2.1.3",
+ "resolved": "https://registry.npmjs.org/json5/-/json5-2.1.3.tgz",
+ "integrity": "sha512-KXPvOm8K9IJKFM0bmdn8QXh7udDh1g/giieX0NLCaMnb4hEiVFqnop2ImTXCc5e0/oHz3LTqmHGtExn5hfMkOA==",
+ "dev": true,
+ "requires": {
+ "minimist": "^1.2.5"
+ }
+ },
+ "jsprim": {
+ "version": "1.4.1",
+ "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.1.tgz",
+ "integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=",
+ "dev": true,
+ "requires": {
+ "assert-plus": "1.0.0",
+ "extsprintf": "1.3.0",
+ "json-schema": "0.2.3",
+ "verror": "1.10.0"
+ }
+ },
+ "kind-of": {
+ "version": "6.0.3",
+ "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz",
+ "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==",
+ "dev": true
+ },
+ "kleur": {
+ "version": "3.0.3",
+ "resolved": "https://registry.npmjs.org/kleur/-/kleur-3.0.3.tgz",
+ "integrity": "sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w==",
+ "dev": true
+ },
+ "leven": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/leven/-/leven-3.1.0.tgz",
+ "integrity": "sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A==",
+ "dev": true
+ },
+ "levn": {
+ "version": "0.3.0",
+ "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz",
+ "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=",
+ "dev": true,
+ "requires": {
+ "prelude-ls": "~1.1.2",
+ "type-check": "~0.3.2"
+ }
+ },
+ "lines-and-columns": {
+ "version": "1.1.6",
+ "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.1.6.tgz",
+ "integrity": "sha1-HADHQ7QzzQpOgHWPe2SldEDZ/wA=",
+ "dev": true
+ },
+ "locate-path": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz",
+ "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==",
+ "dev": true,
+ "requires": {
+ "p-locate": "^4.1.0"
+ }
+ },
+ "lodash": {
+ "version": "4.17.19",
+ "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.19.tgz",
+ "integrity": "sha512-JNvd8XER9GQX0v2qJgsaN/mzFCNA5BRe/j8JN9d+tWyGLSodKQHKFicdwNYzWwI3wjRnaKPsGj1XkBjx/F96DQ==",
+ "dev": true
+ },
+ "lodash.memoize": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/lodash.memoize/-/lodash.memoize-4.1.2.tgz",
+ "integrity": "sha1-vMbEmkKihA7Zl/Mj6tpezRguC/4=",
+ "dev": true
+ },
+ "lodash.sortby": {
+ "version": "4.7.0",
+ "resolved": "https://registry.npmjs.org/lodash.sortby/-/lodash.sortby-4.7.0.tgz",
+ "integrity": "sha1-7dFMgk4sycHgsKG0K7UhBRakJDg=",
+ "dev": true
+ },
+ "make-dir": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz",
+ "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==",
+ "dev": true,
+ "requires": {
+ "semver": "^6.0.0"
+ },
+ "dependencies": {
+ "semver": {
+ "version": "6.3.0",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz",
+ "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==",
+ "dev": true
+ }
+ }
+ },
+ "make-error": {
+ "version": "1.3.6",
+ "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz",
+ "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==",
+ "dev": true
+ },
+ "makeerror": {
+ "version": "1.0.11",
+ "resolved": "https://registry.npmjs.org/makeerror/-/makeerror-1.0.11.tgz",
+ "integrity": "sha1-4BpckQnyr3lmDk6LlYd5AYT1qWw=",
+ "dev": true,
+ "requires": {
+ "tmpl": "1.0.x"
+ }
+ },
+ "map-cache": {
+ "version": "0.2.2",
+ "resolved": "https://registry.npmjs.org/map-cache/-/map-cache-0.2.2.tgz",
+ "integrity": "sha1-wyq9C9ZSXZsFFkW7TyasXcmKDb8=",
+ "dev": true
+ },
+ "map-visit": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/map-visit/-/map-visit-1.0.0.tgz",
+ "integrity": "sha1-7Nyo8TFE5mDxtb1B8S80edmN+48=",
+ "dev": true,
+ "requires": {
+ "object-visit": "^1.0.0"
+ }
+ },
+ "merge-stream": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz",
+ "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==",
+ "dev": true
+ },
+ "micromatch": {
+ "version": "4.0.2",
+ "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.2.tgz",
+ "integrity": "sha512-y7FpHSbMUMoyPbYUSzO6PaZ6FyRnQOpHuKwbo1G+Knck95XVU4QAiKdGEnj5wwoS7PlOgthX/09u5iFJ+aYf5Q==",
+ "dev": true,
+ "requires": {
+ "braces": "^3.0.1",
+ "picomatch": "^2.0.5"
+ }
+ },
+ "mime-db": {
+ "version": "1.44.0",
+ "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.44.0.tgz",
+ "integrity": "sha512-/NOTfLrsPBVeH7YtFPgsVWveuL+4SjjYxaQ1xtM1KMFj7HdxlBlxeyNLzhyJVx7r4rZGJAZ/6lkKCitSc/Nmpg==",
+ "dev": true
+ },
+ "mime-types": {
+ "version": "2.1.27",
+ "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.27.tgz",
+ "integrity": "sha512-JIhqnCasI9yD+SsmkquHBxTSEuZdQX5BuQnS2Vc7puQQQ+8yiP5AY5uWhpdv4YL4VM5c6iliiYWPgJ/nJQLp7w==",
+ "dev": true,
+ "requires": {
+ "mime-db": "1.44.0"
+ }
+ },
+ "mimic-fn": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz",
+ "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==",
+ "dev": true
+ },
+ "mimic-response": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-2.1.0.tgz",
+ "integrity": "sha512-wXqjST+SLt7R009ySCglWBCFpjUygmCIfD790/kVbiGmUgfYGuB14PiTd5DwVxSV4NcYHjzMkoj5LjQZwTQLEA==",
+ "dev": true
+ },
+ "minimatch": {
+ "version": "3.0.4",
+ "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz",
+ "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==",
+ "dev": true,
+ "requires": {
+ "brace-expansion": "^1.1.7"
+ }
+ },
+ "minimist": {
+ "version": "1.2.5",
+ "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz",
+ "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==",
+ "dev": true
+ },
+ "minipass": {
+ "version": "2.9.0",
+ "resolved": "https://registry.npmjs.org/minipass/-/minipass-2.9.0.tgz",
+ "integrity": "sha512-wxfUjg9WebH+CUDX/CdbRlh5SmfZiy/hpkxaRI16Y9W56Pa75sWgd/rvFilSgrauD9NyFymP/+JFV3KwzIsJeg==",
+ "dev": true,
+ "requires": {
+ "safe-buffer": "^5.1.2",
+ "yallist": "^3.0.0"
+ }
+ },
+ "minizlib": {
+ "version": "1.3.3",
+ "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-1.3.3.tgz",
+ "integrity": "sha512-6ZYMOEnmVsdCeTJVE0W9ZD+pVnE8h9Hma/iOwwRDsdQoePpoX56/8B6z3P9VNwppJuBKNRuFDRNRqRWexT9G9Q==",
+ "dev": true,
+ "requires": {
+ "minipass": "^2.9.0"
+ }
+ },
+ "mixin-deep": {
+ "version": "1.3.2",
+ "resolved": "https://registry.npmjs.org/mixin-deep/-/mixin-deep-1.3.2.tgz",
+ "integrity": "sha512-WRoDn//mXBiJ1H40rqa3vH0toePwSsGb45iInWlTySa+Uu4k3tYUSxa2v1KqAiLtvlrSzaExqS1gtk96A9zvEA==",
+ "dev": true,
+ "requires": {
+ "for-in": "^1.0.2",
+ "is-extendable": "^1.0.1"
+ },
+ "dependencies": {
+ "is-extendable": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz",
+ "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==",
+ "dev": true,
+ "requires": {
+ "is-plain-object": "^2.0.4"
+ }
+ }
+ }
+ },
+ "mkdirp": {
+ "version": "0.5.5",
+ "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz",
+ "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==",
+ "dev": true,
+ "requires": {
+ "minimist": "^1.2.5"
+ }
+ },
+ "ms": {
+ "version": "2.1.2",
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz",
+ "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==",
+ "dev": true
+ },
+ "nan": {
+ "version": "2.14.1",
+ "resolved": "https://registry.npmjs.org/nan/-/nan-2.14.1.tgz",
+ "integrity": "sha512-isWHgVjnFjh2x2yuJ/tj3JbwoHu3UC2dX5G/88Cm24yB6YopVgxvBObDY7n5xW6ExmFhJpSEQqFPvq9zaXc8Jw==",
+ "dev": true
+ },
+ "nanomatch": {
+ "version": "1.2.13",
+ "resolved": "https://registry.npmjs.org/nanomatch/-/nanomatch-1.2.13.tgz",
+ "integrity": "sha512-fpoe2T0RbHwBTBUOftAfBPaDEi06ufaUai0mE6Yn1kacc3SnTErfb/h+X94VXzI64rKFHYImXSvdwGGCmwOqCA==",
+ "dev": true,
+ "requires": {
+ "arr-diff": "^4.0.0",
+ "array-unique": "^0.3.2",
+ "define-property": "^2.0.2",
+ "extend-shallow": "^3.0.2",
+ "fragment-cache": "^0.2.1",
+ "is-windows": "^1.0.2",
+ "kind-of": "^6.0.2",
+ "object.pick": "^1.3.0",
+ "regex-not": "^1.0.0",
+ "snapdragon": "^0.8.1",
+ "to-regex": "^3.0.1"
+ }
+ },
+ "natural-compare": {
+ "version": "1.4.0",
+ "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz",
+ "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=",
+ "dev": true
+ },
+ "needle": {
+ "version": "2.5.0",
+ "resolved": "https://registry.npmjs.org/needle/-/needle-2.5.0.tgz",
+ "integrity": "sha512-o/qITSDR0JCyCKEQ1/1bnUXMmznxabbwi/Y4WwJElf+evwJNFNwIDMCCt5IigFVxgeGBJESLohGtIS9gEzo1fA==",
+ "dev": true,
+ "requires": {
+ "debug": "^3.2.6",
+ "iconv-lite": "^0.4.4",
+ "sax": "^1.2.4"
+ }
+ },
+ "nice-try": {
+ "version": "1.0.5",
+ "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz",
+ "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==",
+ "dev": true
+ },
+ "node-int64": {
+ "version": "0.4.0",
+ "resolved": "https://registry.npmjs.org/node-int64/-/node-int64-0.4.0.tgz",
+ "integrity": "sha1-h6kGXNs1XTGC2PlM4RGIuCXGijs=",
+ "dev": true
+ },
+ "node-modules-regexp": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/node-modules-regexp/-/node-modules-regexp-1.0.0.tgz",
+ "integrity": "sha1-jZ2+KJZKSsVxLpExZCEHxx6Q7EA=",
+ "dev": true
+ },
+ "node-notifier": {
+ "version": "7.0.1",
+ "resolved": "https://registry.npmjs.org/node-notifier/-/node-notifier-7.0.1.tgz",
+ "integrity": "sha512-VkzhierE7DBmQEElhTGJIoiZa1oqRijOtgOlsXg32KrJRXsPy0NXFBqWGW/wTswnJlDCs5viRYaqWguqzsKcmg==",
+ "dev": true,
+ "optional": true,
+ "requires": {
+ "growly": "^1.3.0",
+ "is-wsl": "^2.1.1",
+ "semver": "^7.2.1",
+ "shellwords": "^0.1.1",
+ "uuid": "^7.0.3",
+ "which": "^2.0.2"
+ },
+ "dependencies": {
+ "semver": {
+ "version": "7.3.2",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.2.tgz",
+ "integrity": "sha512-OrOb32TeeambH6UrhtShmF7CRDqhL6/5XpPNp2DuRH6+9QLw/orhp72j87v8Qa1ScDkvrrBNpZcDejAirJmfXQ==",
+ "dev": true,
+ "optional": true
+ }
+ }
+ },
+ "node-pre-gyp": {
+ "version": "0.11.0",
+ "resolved": "https://registry.npmjs.org/node-pre-gyp/-/node-pre-gyp-0.11.0.tgz",
+ "integrity": "sha512-TwWAOZb0j7e9eGaf9esRx3ZcLaE5tQ2lvYy1pb5IAaG1a2e2Kv5Lms1Y4hpj+ciXJRofIxxlt5haeQ/2ANeE0Q==",
+ "dev": true,
+ "requires": {
+ "detect-libc": "^1.0.2",
+ "mkdirp": "^0.5.1",
+ "needle": "^2.2.1",
+ "nopt": "^4.0.1",
+ "npm-packlist": "^1.1.6",
+ "npmlog": "^4.0.2",
+ "rc": "^1.2.7",
+ "rimraf": "^2.6.1",
+ "semver": "^5.3.0",
+ "tar": "^4"
+ }
+ },
+ "nopt": {
+ "version": "4.0.3",
+ "resolved": "https://registry.npmjs.org/nopt/-/nopt-4.0.3.tgz",
+ "integrity": "sha512-CvaGwVMztSMJLOeXPrez7fyfObdZqNUK1cPAEzLHrTybIua9pMdmmPR5YwtfNftIOMv3DPUhFaxsZMNTQO20Kg==",
+ "dev": true,
+ "requires": {
+ "abbrev": "1",
+ "osenv": "^0.1.4"
+ }
+ },
+ "normalize-package-data": {
+ "version": "2.5.0",
+ "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz",
+ "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==",
+ "dev": true,
+ "requires": {
+ "hosted-git-info": "^2.1.4",
+ "resolve": "^1.10.0",
+ "semver": "2 || 3 || 4 || 5",
+ "validate-npm-package-license": "^3.0.1"
+ }
+ },
+ "normalize-path": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz",
+ "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==",
+ "dev": true
+ },
+ "npm-bundled": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/npm-bundled/-/npm-bundled-1.1.1.tgz",
+ "integrity": "sha512-gqkfgGePhTpAEgUsGEgcq1rqPXA+tv/aVBlgEzfXwA1yiUJF7xtEt3CtVwOjNYQOVknDk0F20w58Fnm3EtG0fA==",
+ "dev": true,
+ "requires": {
+ "npm-normalize-package-bin": "^1.0.1"
+ }
+ },
+ "npm-normalize-package-bin": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/npm-normalize-package-bin/-/npm-normalize-package-bin-1.0.1.tgz",
+ "integrity": "sha512-EPfafl6JL5/rU+ot6P3gRSCpPDW5VmIzX959Ob1+ySFUuuYHWHekXpwdUZcKP5C+DS4GEtdJluwBjnsNDl+fSA==",
+ "dev": true
+ },
+ "npm-packlist": {
+ "version": "1.4.8",
+ "resolved": "https://registry.npmjs.org/npm-packlist/-/npm-packlist-1.4.8.tgz",
+ "integrity": "sha512-5+AZgwru5IevF5ZdnFglB5wNlHG1AOOuw28WhUq8/8emhBmLv6jX5by4WJCh7lW0uSYZYS6DXqIsyZVIXRZU9A==",
+ "dev": true,
+ "requires": {
+ "ignore-walk": "^3.0.1",
+ "npm-bundled": "^1.0.1",
+ "npm-normalize-package-bin": "^1.0.1"
+ }
+ },
+ "npm-run-path": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-2.0.2.tgz",
+ "integrity": "sha1-NakjLfo11wZ7TLLd8jV7GHFTbF8=",
+ "dev": true,
+ "requires": {
+ "path-key": "^2.0.0"
+ }
+ },
+ "npmlog": {
+ "version": "4.1.2",
+ "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-4.1.2.tgz",
+ "integrity": "sha512-2uUqazuKlTaSI/dC8AzicUck7+IrEaOnN/e0jd3Xtt1KcGpwx30v50mL7oPyr/h9bL3E4aZccVwpwP+5W9Vjkg==",
+ "dev": true,
+ "requires": {
+ "are-we-there-yet": "~1.1.2",
+ "console-control-strings": "~1.1.0",
+ "gauge": "~2.7.3",
+ "set-blocking": "~2.0.0"
+ }
+ },
+ "number-is-nan": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz",
+ "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=",
+ "dev": true
+ },
+ "nwsapi": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/nwsapi/-/nwsapi-2.2.0.tgz",
+ "integrity": "sha512-h2AatdwYH+JHiZpv7pt/gSX1XoRGb7L/qSIeuqA6GwYoF9w1vP1cw42TO0aI2pNyshRK5893hNSl+1//vHK7hQ==",
+ "dev": true
+ },
+ "oauth-sign": {
+ "version": "0.9.0",
+ "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.9.0.tgz",
+ "integrity": "sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ==",
+ "dev": true
+ },
+ "object-assign": {
+ "version": "4.1.1",
+ "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz",
+ "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=",
+ "dev": true
+ },
+ "object-copy": {
+ "version": "0.1.0",
+ "resolved": "https://registry.npmjs.org/object-copy/-/object-copy-0.1.0.tgz",
+ "integrity": "sha1-fn2Fi3gb18mRpBupde04EnVOmYw=",
+ "dev": true,
+ "requires": {
+ "copy-descriptor": "^0.1.0",
+ "define-property": "^0.2.5",
+ "kind-of": "^3.0.3"
+ },
+ "dependencies": {
+ "define-property": {
+ "version": "0.2.5",
+ "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz",
+ "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=",
+ "dev": true,
+ "requires": {
+ "is-descriptor": "^0.1.0"
+ }
+ },
+ "kind-of": {
+ "version": "3.2.2",
+ "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
+ "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
+ "dev": true,
+ "requires": {
+ "is-buffer": "^1.1.5"
+ }
+ }
+ }
+ },
+ "object-visit": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/object-visit/-/object-visit-1.0.1.tgz",
+ "integrity": "sha1-95xEk68MU3e1n+OdOV5BBC3QRbs=",
+ "dev": true,
+ "requires": {
+ "isobject": "^3.0.0"
+ }
+ },
+ "object.pick": {
+ "version": "1.3.0",
+ "resolved": "https://registry.npmjs.org/object.pick/-/object.pick-1.3.0.tgz",
+ "integrity": "sha1-h6EKxMFpS9Lhy/U1kaZhQftd10c=",
+ "dev": true,
+ "requires": {
+ "isobject": "^3.0.1"
+ }
+ },
+ "once": {
+ "version": "1.4.0",
+ "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz",
+ "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=",
+ "dev": true,
+ "requires": {
+ "wrappy": "1"
+ }
+ },
+ "onetime": {
+ "version": "5.1.0",
+ "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.0.tgz",
+ "integrity": "sha512-5NcSkPHhwTVFIQN+TUqXoS5+dlElHXdpAWu9I0HP20YOtIi+aZ0Ct82jdlILDxjLEAWwvm+qj1m6aEtsDVmm6Q==",
+ "dev": true,
+ "requires": {
+ "mimic-fn": "^2.1.0"
+ }
+ },
+ "optionator": {
+ "version": "0.8.3",
+ "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.3.tgz",
+ "integrity": "sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA==",
+ "dev": true,
+ "requires": {
+ "deep-is": "~0.1.3",
+ "fast-levenshtein": "~2.0.6",
+ "levn": "~0.3.0",
+ "prelude-ls": "~1.1.2",
+ "type-check": "~0.3.2",
+ "word-wrap": "~1.2.3"
+ }
+ },
+ "os-homedir": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz",
+ "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=",
+ "dev": true
+ },
+ "os-tmpdir": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz",
+ "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=",
+ "dev": true
+ },
+ "osenv": {
+ "version": "0.1.5",
+ "resolved": "https://registry.npmjs.org/osenv/-/osenv-0.1.5.tgz",
+ "integrity": "sha512-0CWcCECdMVc2Rw3U5w9ZjqX6ga6ubk1xDVKxtBQPK7wis/0F2r9T6k4ydGYhecl7YUBxBVxhL5oisPsNxAPe2g==",
+ "dev": true,
+ "requires": {
+ "os-homedir": "^1.0.0",
+ "os-tmpdir": "^1.0.0"
+ }
+ },
+ "p-each-series": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/p-each-series/-/p-each-series-2.1.0.tgz",
+ "integrity": "sha512-ZuRs1miPT4HrjFa+9fRfOFXxGJfORgelKV9f9nNOWw2gl6gVsRaVDOQP0+MI0G0wGKns1Yacsu0GjOFbTK0JFQ==",
+ "dev": true
+ },
+ "p-finally": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz",
+ "integrity": "sha1-P7z7FbiZpEEjs0ttzBi3JDNqLK4=",
+ "dev": true
+ },
+ "p-limit": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz",
+ "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==",
+ "dev": true,
+ "requires": {
+ "p-try": "^2.0.0"
+ }
+ },
+ "p-locate": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz",
+ "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==",
+ "dev": true,
+ "requires": {
+ "p-limit": "^2.2.0"
+ }
+ },
+ "p-try": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz",
+ "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==",
+ "dev": true
+ },
+ "parse-json": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.0.0.tgz",
+ "integrity": "sha512-OOY5b7PAEFV0E2Fir1KOkxchnZNCdowAJgQ5NuxjpBKTRP3pQhwkrkxqQjeoKJ+fO7bCpmIZaogI4eZGDMEGOw==",
+ "dev": true,
+ "requires": {
+ "@babel/code-frame": "^7.0.0",
+ "error-ex": "^1.3.1",
+ "json-parse-better-errors": "^1.0.1",
+ "lines-and-columns": "^1.1.6"
+ }
+ },
+ "parse5": {
+ "version": "5.1.1",
+ "resolved": "https://registry.npmjs.org/parse5/-/parse5-5.1.1.tgz",
+ "integrity": "sha512-ugq4DFI0Ptb+WWjAdOK16+u/nHfiIrcE+sh8kZMaM0WllQKLI9rOUq6c2b7cwPkXdzfQESqvoqK6ug7U/Yyzug==",
+ "dev": true
+ },
+ "pascalcase": {
+ "version": "0.1.1",
+ "resolved": "https://registry.npmjs.org/pascalcase/-/pascalcase-0.1.1.tgz",
+ "integrity": "sha1-s2PlXoAGym/iF4TS2yK9FdeRfxQ=",
+ "dev": true
+ },
+ "path-exists": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz",
+ "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==",
+ "dev": true
+ },
+ "path-is-absolute": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz",
+ "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=",
+ "dev": true
+ },
+ "path-key": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz",
+ "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=",
+ "dev": true
+ },
+ "path-parse": {
+ "version": "1.0.6",
+ "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz",
+ "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==",
+ "dev": true
+ },
+ "performance-now": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz",
+ "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=",
+ "dev": true
+ },
+ "picomatch": {
+ "version": "2.2.2",
+ "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.2.2.tgz",
+ "integrity": "sha512-q0M/9eZHzmr0AulXyPwNfZjtwZ/RBZlbN3K3CErVrk50T2ASYI7Bye0EvekFY3IP1Nt2DHu0re+V2ZHIpMkuWg==",
+ "dev": true
+ },
+ "pirates": {
+ "version": "4.0.1",
+ "resolved": "https://registry.npmjs.org/pirates/-/pirates-4.0.1.tgz",
+ "integrity": "sha512-WuNqLTbMI3tmfef2TKxlQmAiLHKtFhlsCZnPIpuv2Ow0RDVO8lfy1Opf4NUzlMXLjPl+Men7AuVdX6TA+s+uGA==",
+ "dev": true,
+ "requires": {
+ "node-modules-regexp": "^1.0.0"
+ }
+ },
+ "pkg-dir": {
+ "version": "4.2.0",
+ "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz",
+ "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==",
+ "dev": true,
+ "requires": {
+ "find-up": "^4.0.0"
+ }
+ },
+ "posix-character-classes": {
+ "version": "0.1.1",
+ "resolved": "https://registry.npmjs.org/posix-character-classes/-/posix-character-classes-0.1.1.tgz",
+ "integrity": "sha1-AerA/jta9xoqbAL+q7jB/vfgDqs=",
+ "dev": true
+ },
+ "prelude-ls": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz",
+ "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=",
+ "dev": true
+ },
+ "pretty-format": {
+ "version": "25.5.0",
+ "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-25.5.0.tgz",
+ "integrity": "sha512-kbo/kq2LQ/A/is0PQwsEHM7Ca6//bGPPvU6UnsdDRSKTWxT/ru/xb88v4BJf6a69H+uTytOEsTusT9ksd/1iWQ==",
+ "dev": true,
+ "requires": {
+ "@jest/types": "^25.5.0",
+ "ansi-regex": "^5.0.0",
+ "ansi-styles": "^4.0.0",
+ "react-is": "^16.12.0"
+ }
+ },
+ "process-nextick-args": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz",
+ "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==",
+ "dev": true
+ },
+ "prompts": {
+ "version": "2.3.2",
+ "resolved": "https://registry.npmjs.org/prompts/-/prompts-2.3.2.tgz",
+ "integrity": "sha512-Q06uKs2CkNYVID0VqwfAl9mipo99zkBv/n2JtWY89Yxa3ZabWSrs0e2KTudKVa3peLUvYXMefDqIleLPVUBZMA==",
+ "dev": true,
+ "requires": {
+ "kleur": "^3.0.3",
+ "sisteransi": "^1.0.4"
+ }
+ },
+ "psl": {
+ "version": "1.8.0",
+ "resolved": "https://registry.npmjs.org/psl/-/psl-1.8.0.tgz",
+ "integrity": "sha512-RIdOzyoavK+hA18OGGWDqUTsCLhtA7IcZ/6NCs4fFJaHBDab+pDDmDIByWFRQJq2Cd7r1OoQxBGKOaztq+hjIQ==",
+ "dev": true
+ },
+ "pump": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz",
+ "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==",
+ "dev": true,
+ "requires": {
+ "end-of-stream": "^1.1.0",
+ "once": "^1.3.1"
+ }
+ },
+ "punycode": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz",
+ "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==",
+ "dev": true
+ },
+ "qs": {
+ "version": "6.5.2",
+ "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz",
+ "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==",
+ "dev": true
+ },
+ "rc": {
+ "version": "1.2.8",
+ "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz",
+ "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==",
+ "dev": true,
+ "requires": {
+ "deep-extend": "^0.6.0",
+ "ini": "~1.3.0",
+ "minimist": "^1.2.0",
+ "strip-json-comments": "~2.0.1"
+ }
+ },
+ "react-is": {
+ "version": "16.13.1",
+ "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.13.1.tgz",
+ "integrity": "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==",
+ "dev": true
+ },
+ "read-pkg": {
+ "version": "5.2.0",
+ "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-5.2.0.tgz",
+ "integrity": "sha512-Ug69mNOpfvKDAc2Q8DRpMjjzdtrnv9HcSMX+4VsZxD1aZ6ZzrIE7rlzXBtWTyhULSMKg076AW6WR5iZpD0JiOg==",
+ "dev": true,
+ "requires": {
+ "@types/normalize-package-data": "^2.4.0",
+ "normalize-package-data": "^2.5.0",
+ "parse-json": "^5.0.0",
+ "type-fest": "^0.6.0"
+ },
+ "dependencies": {
+ "type-fest": {
+ "version": "0.6.0",
+ "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.6.0.tgz",
+ "integrity": "sha512-q+MB8nYR1KDLrgr4G5yemftpMC7/QLqVndBmEEdqzmNj5dcFOO4Oo8qlwZE3ULT3+Zim1F8Kq4cBnikNhlCMlg==",
+ "dev": true
+ }
+ }
+ },
+ "read-pkg-up": {
+ "version": "7.0.1",
+ "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-7.0.1.tgz",
+ "integrity": "sha512-zK0TB7Xd6JpCLmlLmufqykGE+/TlOePD6qKClNW7hHDKFh/J7/7gCWGR7joEQEW1bKq3a3yUZSObOoWLFQ4ohg==",
+ "dev": true,
+ "requires": {
+ "find-up": "^4.1.0",
+ "read-pkg": "^5.2.0",
+ "type-fest": "^0.8.1"
+ }
+ },
+ "readable-stream": {
+ "version": "2.3.7",
+ "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz",
+ "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==",
+ "dev": true,
+ "requires": {
+ "core-util-is": "~1.0.0",
+ "inherits": "~2.0.3",
+ "isarray": "~1.0.0",
+ "process-nextick-args": "~2.0.0",
+ "safe-buffer": "~5.1.1",
+ "string_decoder": "~1.1.1",
+ "util-deprecate": "~1.0.1"
+ }
+ },
+ "regex-not": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/regex-not/-/regex-not-1.0.2.tgz",
+ "integrity": "sha512-J6SDjUgDxQj5NusnOtdFxDwN/+HWykR8GELwctJ7mdqhcyy1xEc4SRFHUXvxTp661YaVKAjfRLZ9cCqS6tn32A==",
+ "dev": true,
+ "requires": {
+ "extend-shallow": "^3.0.2",
+ "safe-regex": "^1.1.0"
+ }
+ },
+ "remove-trailing-separator": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz",
+ "integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=",
+ "dev": true
+ },
+ "repeat-element": {
+ "version": "1.1.3",
+ "resolved": "https://registry.npmjs.org/repeat-element/-/repeat-element-1.1.3.tgz",
+ "integrity": "sha512-ahGq0ZnV5m5XtZLMb+vP76kcAM5nkLqk0lpqAuojSKGgQtn4eRi4ZZGm2olo2zKFH+sMsWaqOCW1dqAnOru72g==",
+ "dev": true
+ },
+ "repeat-string": {
+ "version": "1.6.1",
+ "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz",
+ "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=",
+ "dev": true
+ },
+ "request": {
+ "version": "2.88.2",
+ "resolved": "https://registry.npmjs.org/request/-/request-2.88.2.tgz",
+ "integrity": "sha512-MsvtOrfG9ZcrOwAW+Qi+F6HbD0CWXEh9ou77uOb7FM2WPhwT7smM833PzanhJLsgXjN89Ir6V2PczXNnMpwKhw==",
+ "dev": true,
+ "requires": {
+ "aws-sign2": "~0.7.0",
+ "aws4": "^1.8.0",
+ "caseless": "~0.12.0",
+ "combined-stream": "~1.0.6",
+ "extend": "~3.0.2",
+ "forever-agent": "~0.6.1",
+ "form-data": "~2.3.2",
+ "har-validator": "~5.1.3",
+ "http-signature": "~1.2.0",
+ "is-typedarray": "~1.0.0",
+ "isstream": "~0.1.2",
+ "json-stringify-safe": "~5.0.1",
+ "mime-types": "~2.1.19",
+ "oauth-sign": "~0.9.0",
+ "performance-now": "^2.1.0",
+ "qs": "~6.5.2",
+ "safe-buffer": "^5.1.2",
+ "tough-cookie": "~2.5.0",
+ "tunnel-agent": "^0.6.0",
+ "uuid": "^3.3.2"
+ },
+ "dependencies": {
+ "tough-cookie": {
+ "version": "2.5.0",
+ "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.5.0.tgz",
+ "integrity": "sha512-nlLsUzgm1kfLXSXfRZMc1KLAugd4hqJHDTvc2hDIwS3mZAfMEuMbc03SujMF+GEcpaX/qboeycw6iO8JwVv2+g==",
+ "dev": true,
+ "requires": {
+ "psl": "^1.1.28",
+ "punycode": "^2.1.1"
+ }
+ },
+ "uuid": {
+ "version": "3.4.0",
+ "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.4.0.tgz",
+ "integrity": "sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A==",
+ "dev": true
+ }
+ }
+ },
+ "request-promise-core": {
+ "version": "1.1.3",
+ "resolved": "https://registry.npmjs.org/request-promise-core/-/request-promise-core-1.1.3.tgz",
+ "integrity": "sha512-QIs2+ArIGQVp5ZYbWD5ZLCY29D5CfWizP8eWnm8FoGD1TX61veauETVQbrV60662V0oFBkrDOuaBI8XgtuyYAQ==",
+ "dev": true,
+ "requires": {
+ "lodash": "^4.17.15"
+ }
+ },
+ "request-promise-native": {
+ "version": "1.0.8",
+ "resolved": "https://registry.npmjs.org/request-promise-native/-/request-promise-native-1.0.8.tgz",
+ "integrity": "sha512-dapwLGqkHtwL5AEbfenuzjTYg35Jd6KPytsC2/TLkVMz8rm+tNt72MGUWT1RP/aYawMpN6HqbNGBQaRcBtjQMQ==",
+ "dev": true,
+ "requires": {
+ "request-promise-core": "1.1.3",
+ "stealthy-require": "^1.1.1",
+ "tough-cookie": "^2.3.3"
+ },
+ "dependencies": {
+ "tough-cookie": {
+ "version": "2.5.0",
+ "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.5.0.tgz",
+ "integrity": "sha512-nlLsUzgm1kfLXSXfRZMc1KLAugd4hqJHDTvc2hDIwS3mZAfMEuMbc03SujMF+GEcpaX/qboeycw6iO8JwVv2+g==",
+ "dev": true,
+ "requires": {
+ "psl": "^1.1.28",
+ "punycode": "^2.1.1"
+ }
+ }
+ }
+ },
+ "require-directory": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz",
+ "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=",
+ "dev": true
+ },
+ "require-main-filename": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-2.0.0.tgz",
+ "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==",
+ "dev": true
+ },
+ "resolve": {
+ "version": "1.17.0",
+ "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.17.0.tgz",
+ "integrity": "sha512-ic+7JYiV8Vi2yzQGFWOkiZD5Z9z7O2Zhm9XMaTxdJExKasieFCr+yXZ/WmXsckHiKl12ar0y6XiXDx3m4RHn1w==",
+ "dev": true,
+ "requires": {
+ "path-parse": "^1.0.6"
+ }
+ },
+ "resolve-cwd": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/resolve-cwd/-/resolve-cwd-3.0.0.tgz",
+ "integrity": "sha512-OrZaX2Mb+rJCpH/6CpSqt9xFVpN++x01XnN2ie9g6P5/3xelLAkXWVADpdz1IHD/KFfEXyE6V0U01OQ3UO2rEg==",
+ "dev": true,
+ "requires": {
+ "resolve-from": "^5.0.0"
+ }
+ },
+ "resolve-from": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz",
+ "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==",
+ "dev": true
+ },
+ "resolve-url": {
+ "version": "0.2.1",
+ "resolved": "https://registry.npmjs.org/resolve-url/-/resolve-url-0.2.1.tgz",
+ "integrity": "sha1-LGN/53yJOv0qZj/iGqkIAGjiBSo=",
+ "dev": true
+ },
+ "ret": {
+ "version": "0.1.15",
+ "resolved": "https://registry.npmjs.org/ret/-/ret-0.1.15.tgz",
+ "integrity": "sha512-TTlYpa+OL+vMMNG24xSlQGEJ3B/RzEfUlLct7b5G/ytav+wPrplCpVMFuwzXbkecJrb6IYo1iFb0S9v37754mg==",
+ "dev": true
+ },
+ "rimraf": {
+ "version": "2.7.1",
+ "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz",
+ "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==",
+ "dev": true,
+ "requires": {
+ "glob": "^7.1.3"
+ }
+ },
+ "rsvp": {
+ "version": "4.8.5",
+ "resolved": "https://registry.npmjs.org/rsvp/-/rsvp-4.8.5.tgz",
+ "integrity": "sha512-nfMOlASu9OnRJo1mbEk2cz0D56a1MBNrJ7orjRZQG10XDyuvwksKbuXNp6qa+kbn839HwjwhBzhFmdsaEAfauA==",
+ "dev": true
+ },
+ "safe-buffer": {
+ "version": "5.1.2",
+ "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz",
+ "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==",
+ "dev": true
+ },
+ "safe-regex": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/safe-regex/-/safe-regex-1.1.0.tgz",
+ "integrity": "sha1-QKNmnzsHfR6UPURinhV91IAjvy4=",
+ "dev": true,
+ "requires": {
+ "ret": "~0.1.10"
+ }
+ },
+ "safer-buffer": {
+ "version": "2.1.2",
+ "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz",
+ "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==",
+ "dev": true
+ },
+ "sane": {
+ "version": "4.1.0",
+ "resolved": "https://registry.npmjs.org/sane/-/sane-4.1.0.tgz",
+ "integrity": "sha512-hhbzAgTIX8O7SHfp2c8/kREfEn4qO/9q8C9beyY6+tvZ87EpoZ3i1RIEvp27YBswnNbY9mWd6paKVmKbAgLfZA==",
+ "dev": true,
+ "requires": {
+ "@cnakazawa/watch": "^1.0.3",
+ "anymatch": "^2.0.0",
+ "capture-exit": "^2.0.0",
+ "exec-sh": "^0.3.2",
+ "execa": "^1.0.0",
+ "fb-watchman": "^2.0.0",
+ "micromatch": "^3.1.4",
+ "minimist": "^1.1.1",
+ "walker": "~1.0.5"
+ },
+ "dependencies": {
+ "anymatch": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-2.0.0.tgz",
+ "integrity": "sha512-5teOsQWABXHHBFP9y3skS5P3d/WfWXpv3FUpy+LorMrNYaT9pI4oLMQX7jzQ2KklNpGpWHzdCXTDT2Y3XGlZBw==",
+ "dev": true,
+ "requires": {
+ "micromatch": "^3.1.4",
+ "normalize-path": "^2.1.1"
+ }
+ },
+ "braces": {
+ "version": "2.3.2",
+ "resolved": "https://registry.npmjs.org/braces/-/braces-2.3.2.tgz",
+ "integrity": "sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w==",
+ "dev": true,
+ "requires": {
+ "arr-flatten": "^1.1.0",
+ "array-unique": "^0.3.2",
+ "extend-shallow": "^2.0.1",
+ "fill-range": "^4.0.0",
+ "isobject": "^3.0.1",
+ "repeat-element": "^1.1.2",
+ "snapdragon": "^0.8.1",
+ "snapdragon-node": "^2.0.1",
+ "split-string": "^3.0.2",
+ "to-regex": "^3.0.1"
+ },
+ "dependencies": {
+ "extend-shallow": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
+ "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
+ "dev": true,
+ "requires": {
+ "is-extendable": "^0.1.0"
+ }
+ }
+ }
+ },
+ "fill-range": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-4.0.0.tgz",
+ "integrity": "sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc=",
+ "dev": true,
+ "requires": {
+ "extend-shallow": "^2.0.1",
+ "is-number": "^3.0.0",
+ "repeat-string": "^1.6.1",
+ "to-regex-range": "^2.1.0"
+ },
+ "dependencies": {
+ "extend-shallow": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
+ "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
+ "dev": true,
+ "requires": {
+ "is-extendable": "^0.1.0"
+ }
+ }
+ }
+ },
+ "is-number": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz",
+ "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=",
+ "dev": true,
+ "requires": {
+ "kind-of": "^3.0.2"
+ },
+ "dependencies": {
+ "kind-of": {
+ "version": "3.2.2",
+ "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
+ "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
+ "dev": true,
+ "requires": {
+ "is-buffer": "^1.1.5"
+ }
+ }
+ }
+ },
+ "micromatch": {
+ "version": "3.1.10",
+ "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz",
+ "integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==",
+ "dev": true,
+ "requires": {
+ "arr-diff": "^4.0.0",
+ "array-unique": "^0.3.2",
+ "braces": "^2.3.1",
+ "define-property": "^2.0.2",
+ "extend-shallow": "^3.0.2",
+ "extglob": "^2.0.4",
+ "fragment-cache": "^0.2.1",
+ "kind-of": "^6.0.2",
+ "nanomatch": "^1.2.9",
+ "object.pick": "^1.3.0",
+ "regex-not": "^1.0.0",
+ "snapdragon": "^0.8.1",
+ "to-regex": "^3.0.2"
+ }
+ },
+ "normalize-path": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz",
+ "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=",
+ "dev": true,
+ "requires": {
+ "remove-trailing-separator": "^1.0.1"
+ }
+ },
+ "to-regex-range": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-2.1.1.tgz",
+ "integrity": "sha1-fIDBe53+vlmeJzZ+DU3VWQFB2zg=",
+ "dev": true,
+ "requires": {
+ "is-number": "^3.0.0",
+ "repeat-string": "^1.6.1"
+ }
+ }
+ }
+ },
+ "sax": {
+ "version": "1.2.4",
+ "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz",
+ "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==",
+ "dev": true
+ },
+ "saxes": {
+ "version": "5.0.1",
+ "resolved": "https://registry.npmjs.org/saxes/-/saxes-5.0.1.tgz",
+ "integrity": "sha512-5LBh1Tls8c9xgGjw3QrMwETmTMVk0oFgvrFSvWx62llR2hcEInrKNZ2GZCCuuy2lvWrdl5jhbpeqc5hRYKFOcw==",
+ "dev": true,
+ "requires": {
+ "xmlchars": "^2.2.0"
+ }
+ },
+ "semver": {
+ "version": "5.7.1",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz",
+ "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==",
+ "dev": true
+ },
+ "set-blocking": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz",
+ "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=",
+ "dev": true
+ },
+ "set-value": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/set-value/-/set-value-2.0.1.tgz",
+ "integrity": "sha512-JxHc1weCN68wRY0fhCoXpyK55m/XPHafOmK4UWD7m2CI14GMcFypt4w/0+NV5f/ZMby2F6S2wwA7fgynh9gWSw==",
+ "dev": true,
+ "requires": {
+ "extend-shallow": "^2.0.1",
+ "is-extendable": "^0.1.1",
+ "is-plain-object": "^2.0.3",
+ "split-string": "^3.0.1"
+ },
+ "dependencies": {
+ "extend-shallow": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
+ "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
+ "dev": true,
+ "requires": {
+ "is-extendable": "^0.1.0"
+ }
+ }
+ }
+ },
+ "shebang-command": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz",
+ "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=",
+ "dev": true,
+ "requires": {
+ "shebang-regex": "^1.0.0"
+ }
+ },
+ "shebang-regex": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz",
+ "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=",
+ "dev": true
+ },
+ "shellwords": {
+ "version": "0.1.1",
+ "resolved": "https://registry.npmjs.org/shellwords/-/shellwords-0.1.1.tgz",
+ "integrity": "sha512-vFwSUfQvqybiICwZY5+DAWIPLKsWO31Q91JSKl3UYv+K5c2QRPzn0qzec6QPu1Qc9eHYItiP3NdJqNVqetYAww==",
+ "dev": true,
+ "optional": true
+ },
+ "signal-exit": {
+ "version": "3.0.3",
+ "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.3.tgz",
+ "integrity": "sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA==",
+ "dev": true
+ },
+ "simple-concat": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/simple-concat/-/simple-concat-1.0.0.tgz",
+ "integrity": "sha1-c0TLuLbib7J9ZrL8hvn21Zl1IcY=",
+ "dev": true
+ },
+ "simple-get": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/simple-get/-/simple-get-3.1.0.tgz",
+ "integrity": "sha512-bCR6cP+aTdScaQCnQKbPKtJOKDp/hj9EDLJo3Nw4y1QksqaovlW/bnptB6/c1e+qmNIDHRK+oXFDdEqBT8WzUA==",
+ "dev": true,
+ "requires": {
+ "decompress-response": "^4.2.0",
+ "once": "^1.3.1",
+ "simple-concat": "^1.0.0"
+ }
+ },
+ "sisteransi": {
+ "version": "1.0.5",
+ "resolved": "https://registry.npmjs.org/sisteransi/-/sisteransi-1.0.5.tgz",
+ "integrity": "sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg==",
+ "dev": true
+ },
+ "slash": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz",
+ "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==",
+ "dev": true
+ },
+ "snapdragon": {
+ "version": "0.8.2",
+ "resolved": "https://registry.npmjs.org/snapdragon/-/snapdragon-0.8.2.tgz",
+ "integrity": "sha512-FtyOnWN/wCHTVXOMwvSv26d+ko5vWlIDD6zoUJ7LW8vh+ZBC8QdljveRP+crNrtBwioEUWy/4dMtbBjA4ioNlg==",
+ "dev": true,
+ "requires": {
+ "base": "^0.11.1",
+ "debug": "^2.2.0",
+ "define-property": "^0.2.5",
+ "extend-shallow": "^2.0.1",
+ "map-cache": "^0.2.2",
+ "source-map": "^0.5.6",
+ "source-map-resolve": "^0.5.0",
+ "use": "^3.1.0"
+ },
+ "dependencies": {
+ "debug": {
+ "version": "2.6.9",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
+ "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
+ "dev": true,
+ "requires": {
+ "ms": "2.0.0"
+ }
+ },
+ "define-property": {
+ "version": "0.2.5",
+ "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz",
+ "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=",
+ "dev": true,
+ "requires": {
+ "is-descriptor": "^0.1.0"
+ }
+ },
+ "extend-shallow": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz",
+ "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=",
+ "dev": true,
+ "requires": {
+ "is-extendable": "^0.1.0"
+ }
+ },
+ "ms": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
+ "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=",
+ "dev": true
+ },
+ "source-map": {
+ "version": "0.5.7",
+ "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz",
+ "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=",
+ "dev": true
+ }
+ }
+ },
+ "snapdragon-node": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/snapdragon-node/-/snapdragon-node-2.1.1.tgz",
+ "integrity": "sha512-O27l4xaMYt/RSQ5TR3vpWCAB5Kb/czIcqUFOM/C4fYcLnbZUc1PkjTAMjof2pBWaSTwOUd6qUHcFGVGj7aIwnw==",
+ "dev": true,
+ "requires": {
+ "define-property": "^1.0.0",
+ "isobject": "^3.0.0",
+ "snapdragon-util": "^3.0.1"
+ },
+ "dependencies": {
+ "define-property": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz",
+ "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=",
+ "dev": true,
+ "requires": {
+ "is-descriptor": "^1.0.0"
+ }
+ },
+ "is-accessor-descriptor": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz",
+ "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==",
+ "dev": true,
+ "requires": {
+ "kind-of": "^6.0.0"
+ }
+ },
+ "is-data-descriptor": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz",
+ "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==",
+ "dev": true,
+ "requires": {
+ "kind-of": "^6.0.0"
+ }
+ },
+ "is-descriptor": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz",
+ "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==",
+ "dev": true,
+ "requires": {
+ "is-accessor-descriptor": "^1.0.0",
+ "is-data-descriptor": "^1.0.0",
+ "kind-of": "^6.0.2"
+ }
+ }
+ }
+ },
+ "snapdragon-util": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/snapdragon-util/-/snapdragon-util-3.0.1.tgz",
+ "integrity": "sha512-mbKkMdQKsjX4BAL4bRYTj21edOf8cN7XHdYUJEe+Zn99hVEYcMvKPct1IqNe7+AZPirn8BCDOQBHQZknqmKlZQ==",
+ "dev": true,
+ "requires": {
+ "kind-of": "^3.2.0"
+ },
+ "dependencies": {
+ "kind-of": {
+ "version": "3.2.2",
+ "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
+ "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
+ "dev": true,
+ "requires": {
+ "is-buffer": "^1.1.5"
+ }
+ }
+ }
+ },
+ "source-map": {
+ "version": "0.6.1",
+ "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz",
+ "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==",
+ "dev": true
+ },
+ "source-map-resolve": {
+ "version": "0.5.3",
+ "resolved": "https://registry.npmjs.org/source-map-resolve/-/source-map-resolve-0.5.3.tgz",
+ "integrity": "sha512-Htz+RnsXWk5+P2slx5Jh3Q66vhQj1Cllm0zvnaY98+NFx+Dv2CF/f5O/t8x+KaNdrdIAsruNzoh/KpialbqAnw==",
+ "dev": true,
+ "requires": {
+ "atob": "^2.1.2",
+ "decode-uri-component": "^0.2.0",
+ "resolve-url": "^0.2.1",
+ "source-map-url": "^0.4.0",
+ "urix": "^0.1.0"
+ }
+ },
+ "source-map-support": {
+ "version": "0.5.19",
+ "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.19.tgz",
+ "integrity": "sha512-Wonm7zOCIJzBGQdB+thsPar0kYuCIzYvxZwlBa87yi/Mdjv7Tip2cyVbLj5o0cFPN4EVkuTwb3GDDyUx2DGnGw==",
+ "dev": true,
+ "requires": {
+ "buffer-from": "^1.0.0",
+ "source-map": "^0.6.0"
+ }
+ },
+ "source-map-url": {
+ "version": "0.4.0",
+ "resolved": "https://registry.npmjs.org/source-map-url/-/source-map-url-0.4.0.tgz",
+ "integrity": "sha1-PpNdfd1zYxuXZZlW1VEo6HtQhKM=",
+ "dev": true
+ },
+ "spdx-correct": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.1.tgz",
+ "integrity": "sha512-cOYcUWwhCuHCXi49RhFRCyJEK3iPj1Ziz9DpViV3tbZOwXD49QzIN3MpOLJNxh2qwq2lJJZaKMVw9qNi4jTC0w==",
+ "dev": true,
+ "requires": {
+ "spdx-expression-parse": "^3.0.0",
+ "spdx-license-ids": "^3.0.0"
+ }
+ },
+ "spdx-exceptions": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz",
+ "integrity": "sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A==",
+ "dev": true
+ },
+ "spdx-expression-parse": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz",
+ "integrity": "sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==",
+ "dev": true,
+ "requires": {
+ "spdx-exceptions": "^2.1.0",
+ "spdx-license-ids": "^3.0.0"
+ }
+ },
+ "spdx-license-ids": {
+ "version": "3.0.5",
+ "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.5.tgz",
+ "integrity": "sha512-J+FWzZoynJEXGphVIS+XEh3kFSjZX/1i9gFBaWQcB+/tmpe2qUsSBABpcxqxnAxFdiUFEgAX1bjYGQvIZmoz9Q==",
+ "dev": true
+ },
+ "split-string": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/split-string/-/split-string-3.1.0.tgz",
+ "integrity": "sha512-NzNVhJDYpwceVVii8/Hu6DKfD2G+NrQHlS/V/qgv763EYudVwEcMQNxd2lh+0VrUByXN/oJkl5grOhYWvQUYiw==",
+ "dev": true,
+ "requires": {
+ "extend-shallow": "^3.0.0"
+ }
+ },
+ "sprintf-js": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz",
+ "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=",
+ "dev": true
+ },
+ "sshpk": {
+ "version": "1.16.1",
+ "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.16.1.tgz",
+ "integrity": "sha512-HXXqVUq7+pcKeLqqZj6mHFUMvXtOJt1uoUx09pFW6011inTMxqI8BA8PM95myrIyyKwdnzjdFjLiE6KBPVtJIg==",
+ "dev": true,
+ "requires": {
+ "asn1": "~0.2.3",
+ "assert-plus": "^1.0.0",
+ "bcrypt-pbkdf": "^1.0.0",
+ "dashdash": "^1.12.0",
+ "ecc-jsbn": "~0.1.1",
+ "getpass": "^0.1.1",
+ "jsbn": "~0.1.0",
+ "safer-buffer": "^2.0.2",
+ "tweetnacl": "~0.14.0"
+ }
+ },
+ "stack-utils": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/stack-utils/-/stack-utils-2.0.2.tgz",
+ "integrity": "sha512-0H7QK2ECz3fyZMzQ8rH0j2ykpfbnd20BFtfg/SqVC2+sCTtcw0aDTGB7dk+de4U4uUeuz6nOtJcrkFFLG1B0Rg==",
+ "dev": true,
+ "requires": {
+ "escape-string-regexp": "^2.0.0"
+ },
+ "dependencies": {
+ "escape-string-regexp": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz",
+ "integrity": "sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w==",
+ "dev": true
+ }
+ }
+ },
+ "static-extend": {
+ "version": "0.1.2",
+ "resolved": "https://registry.npmjs.org/static-extend/-/static-extend-0.1.2.tgz",
+ "integrity": "sha1-YICcOcv/VTNyJv1eC1IPNB8ftcY=",
+ "dev": true,
+ "requires": {
+ "define-property": "^0.2.5",
+ "object-copy": "^0.1.0"
+ },
+ "dependencies": {
+ "define-property": {
+ "version": "0.2.5",
+ "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz",
+ "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=",
+ "dev": true,
+ "requires": {
+ "is-descriptor": "^0.1.0"
+ }
+ }
+ }
+ },
+ "stealthy-require": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/stealthy-require/-/stealthy-require-1.1.1.tgz",
+ "integrity": "sha1-NbCYdbT/SfJqd35QmzCQoyJr8ks=",
+ "dev": true
+ },
+ "string-length": {
+ "version": "4.0.1",
+ "resolved": "https://registry.npmjs.org/string-length/-/string-length-4.0.1.tgz",
+ "integrity": "sha512-PKyXUd0LK0ePjSOnWn34V2uD6acUWev9uy0Ft05k0E8xRW+SKcA0F7eMr7h5xlzfn+4O3N+55rduYyet3Jk+jw==",
+ "dev": true,
+ "requires": {
+ "char-regex": "^1.0.2",
+ "strip-ansi": "^6.0.0"
+ },
+ "dependencies": {
+ "strip-ansi": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz",
+ "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==",
+ "dev": true,
+ "requires": {
+ "ansi-regex": "^5.0.0"
+ }
+ }
+ }
+ },
+ "string-width": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz",
+ "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=",
+ "dev": true,
+ "requires": {
+ "code-point-at": "^1.0.0",
+ "is-fullwidth-code-point": "^1.0.0",
+ "strip-ansi": "^3.0.0"
+ }
+ },
+ "string_decoder": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz",
+ "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==",
+ "dev": true,
+ "requires": {
+ "safe-buffer": "~5.1.0"
+ }
+ },
+ "strip-ansi": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz",
+ "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=",
+ "dev": true,
+ "requires": {
+ "ansi-regex": "^2.0.0"
+ },
+ "dependencies": {
+ "ansi-regex": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz",
+ "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=",
+ "dev": true
+ }
+ }
+ },
+ "strip-bom": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-4.0.0.tgz",
+ "integrity": "sha512-3xurFv5tEgii33Zi8Jtp55wEIILR9eh34FAW00PZf+JnSsTmV/ioewSgQl97JHvgjoRGwPShsWm+IdrxB35d0w==",
+ "dev": true
+ },
+ "strip-eof": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/strip-eof/-/strip-eof-1.0.0.tgz",
+ "integrity": "sha1-u0P/VZim6wXYm1n80SnJgzE2Br8=",
+ "dev": true
+ },
+ "strip-final-newline": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz",
+ "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==",
+ "dev": true
+ },
+ "strip-json-comments": {
+ "version": "2.0.1",
+ "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz",
+ "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=",
+ "dev": true
+ },
+ "supports-color": {
+ "version": "7.1.0",
+ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.1.0.tgz",
+ "integrity": "sha512-oRSIpR8pxT1Wr2FquTNnGet79b3BWljqOuoW/h4oBhxJ/HUbX5nX6JSruTkvXDCFMwDPvsaTTbvMLKZWSy0R5g==",
+ "dev": true,
+ "requires": {
+ "has-flag": "^4.0.0"
+ }
+ },
+ "supports-hyperlinks": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/supports-hyperlinks/-/supports-hyperlinks-2.1.0.tgz",
+ "integrity": "sha512-zoE5/e+dnEijk6ASB6/qrK+oYdm2do1hjoLWrqUC/8WEIW1gbxFcKuBof7sW8ArN6e+AYvsE8HBGiVRWL/F5CA==",
+ "dev": true,
+ "requires": {
+ "has-flag": "^4.0.0",
+ "supports-color": "^7.0.0"
+ }
+ },
+ "symbol-tree": {
+ "version": "3.2.4",
+ "resolved": "https://registry.npmjs.org/symbol-tree/-/symbol-tree-3.2.4.tgz",
+ "integrity": "sha512-9QNk5KwDF+Bvz+PyObkmSYjI5ksVUYtjW7AU22r2NKcfLJcXp96hkDWU3+XndOsUb+AQ9QhfzfCT2O+CNWT5Tw==",
+ "dev": true
+ },
+ "tar": {
+ "version": "4.4.13",
+ "resolved": "https://registry.npmjs.org/tar/-/tar-4.4.13.tgz",
+ "integrity": "sha512-w2VwSrBoHa5BsSyH+KxEqeQBAllHhccyMFVHtGtdMpF4W7IRWfZjFiQceJPChOeTsSDVUpER2T8FA93pr0L+QA==",
+ "dev": true,
+ "requires": {
+ "chownr": "^1.1.1",
+ "fs-minipass": "^1.2.5",
+ "minipass": "^2.8.6",
+ "minizlib": "^1.2.1",
+ "mkdirp": "^0.5.0",
+ "safe-buffer": "^5.1.2",
+ "yallist": "^3.0.3"
+ }
+ },
+ "terminal-link": {
+ "version": "2.1.1",
+ "resolved": "https://registry.npmjs.org/terminal-link/-/terminal-link-2.1.1.tgz",
+ "integrity": "sha512-un0FmiRUQNr5PJqy9kP7c40F5BOfpGlYTrxonDChEZB7pzZxRNp/bt+ymiy9/npwXya9KH99nJ/GXFIiUkYGFQ==",
+ "dev": true,
+ "requires": {
+ "ansi-escapes": "^4.2.1",
+ "supports-hyperlinks": "^2.0.0"
+ }
+ },
+ "test-exclude": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz",
+ "integrity": "sha512-cAGWPIyOHU6zlmg88jwm7VRyXnMN7iV68OGAbYDk/Mh/xC/pzVPlQtY6ngoIH/5/tciuhGfvESU8GrHrcxD56w==",
+ "dev": true,
+ "requires": {
+ "@istanbuljs/schema": "^0.1.2",
+ "glob": "^7.1.4",
+ "minimatch": "^3.0.4"
+ }
+ },
+ "throat": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/throat/-/throat-5.0.0.tgz",
+ "integrity": "sha512-fcwX4mndzpLQKBS1DVYhGAcYaYt7vsHNIvQV+WXMvnow5cgjPphq5CaayLaGsjRdSCKZFNGt7/GYAuXaNOiYCA==",
+ "dev": true
+ },
+ "tmpl": {
+ "version": "1.0.4",
+ "resolved": "https://registry.npmjs.org/tmpl/-/tmpl-1.0.4.tgz",
+ "integrity": "sha1-I2QN17QtAEM5ERQIIOXPRA5SHdE=",
+ "dev": true
+ },
+ "to-fast-properties": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz",
+ "integrity": "sha1-3F5pjL0HkmW8c+A3doGk5Og/YW4=",
+ "dev": true
+ },
+ "to-object-path": {
+ "version": "0.3.0",
+ "resolved": "https://registry.npmjs.org/to-object-path/-/to-object-path-0.3.0.tgz",
+ "integrity": "sha1-KXWIt7Dn4KwI4E5nL4XB9JmeF68=",
+ "dev": true,
+ "requires": {
+ "kind-of": "^3.0.2"
+ },
+ "dependencies": {
+ "kind-of": {
+ "version": "3.2.2",
+ "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz",
+ "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=",
+ "dev": true,
+ "requires": {
+ "is-buffer": "^1.1.5"
+ }
+ }
+ }
+ },
+ "to-regex": {
+ "version": "3.0.2",
+ "resolved": "https://registry.npmjs.org/to-regex/-/to-regex-3.0.2.tgz",
+ "integrity": "sha512-FWtleNAtZ/Ki2qtqej2CXTOayOH9bHDQF+Q48VpWyDXjbYxA4Yz8iDB31zXOBUlOHHKidDbqGVrTUvQMPmBGBw==",
+ "dev": true,
+ "requires": {
+ "define-property": "^2.0.2",
+ "extend-shallow": "^3.0.2",
+ "regex-not": "^1.0.2",
+ "safe-regex": "^1.1.0"
+ }
+ },
+ "to-regex-range": {
+ "version": "5.0.1",
+ "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz",
+ "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==",
+ "dev": true,
+ "requires": {
+ "is-number": "^7.0.0"
+ }
+ },
+ "tough-cookie": {
+ "version": "3.0.1",
+ "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-3.0.1.tgz",
+ "integrity": "sha512-yQyJ0u4pZsv9D4clxO69OEjLWYw+jbgspjTue4lTQZLfV0c5l1VmK2y1JK8E9ahdpltPOaAThPcp5nKPUgSnsg==",
+ "dev": true,
+ "requires": {
+ "ip-regex": "^2.1.0",
+ "psl": "^1.1.28",
+ "punycode": "^2.1.1"
+ }
+ },
+ "tr46": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/tr46/-/tr46-2.0.2.tgz",
+ "integrity": "sha512-3n1qG+/5kg+jrbTzwAykB5yRYtQCTqOGKq5U5PE3b0a1/mzo6snDhjGS0zJVJunO0NrT3Dg1MLy5TjWP/UJppg==",
+ "dev": true,
+ "requires": {
+ "punycode": "^2.1.1"
+ }
+ },
+ "ts-jest": {
+ "version": "26.1.2",
+ "resolved": "https://registry.npmjs.org/ts-jest/-/ts-jest-26.1.2.tgz",
+ "integrity": "sha512-V4SyBDO9gOdEh+AF4KtXJeP+EeI4PkOrxcA8ptl4o8nCXUVM5Gg/8ngGKneS5BsZaR9DXVQNqj9k+iqGAnpGow==",
+ "dev": true,
+ "requires": {
+ "bs-logger": "0.x",
+ "buffer-from": "1.x",
+ "fast-json-stable-stringify": "2.x",
+ "jest-util": "26.x",
+ "json5": "2.x",
+ "lodash.memoize": "4.x",
+ "make-error": "1.x",
+ "mkdirp": "1.x",
+ "semver": "7.x",
+ "yargs-parser": "18.x"
+ },
+ "dependencies": {
+ "mkdirp": {
+ "version": "1.0.4",
+ "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-1.0.4.tgz",
+ "integrity": "sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==",
+ "dev": true
+ },
+ "semver": {
+ "version": "7.3.2",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.2.tgz",
+ "integrity": "sha512-OrOb32TeeambH6UrhtShmF7CRDqhL6/5XpPNp2DuRH6+9QLw/orhp72j87v8Qa1ScDkvrrBNpZcDejAirJmfXQ==",
+ "dev": true
+ }
+ }
+ },
+ "tunnel-agent": {
+ "version": "0.6.0",
+ "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz",
+ "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=",
+ "dev": true,
+ "requires": {
+ "safe-buffer": "^5.0.1"
+ }
+ },
+ "tweetnacl": {
+ "version": "0.14.5",
+ "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz",
+ "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=",
+ "dev": true
+ },
+ "type-check": {
+ "version": "0.3.2",
+ "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz",
+ "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=",
+ "dev": true,
+ "requires": {
+ "prelude-ls": "~1.1.2"
+ }
+ },
+ "type-detect": {
+ "version": "4.0.8",
+ "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz",
+ "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==",
+ "dev": true
+ },
+ "type-fest": {
+ "version": "0.8.1",
+ "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz",
+ "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==",
+ "dev": true
+ },
+ "typedarray-to-buffer": {
+ "version": "3.1.5",
+ "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz",
+ "integrity": "sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==",
+ "dev": true,
+ "requires": {
+ "is-typedarray": "^1.0.0"
+ }
+ },
+ "typescript": {
+ "version": "3.9.6",
+ "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.9.6.tgz",
+ "integrity": "sha512-Pspx3oKAPJtjNwE92YS05HQoY7z2SFyOpHo9MqJor3BXAGNaPUs83CuVp9VISFkSjyRfiTpmKuAYGJB7S7hOxw==",
+ "dev": true
+ },
+ "union-value": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/union-value/-/union-value-1.0.1.tgz",
+ "integrity": "sha512-tJfXmxMeWYnczCVs7XAEvIV7ieppALdyepWMkHkwciRpZraG/xwT+s2JN8+pr1+8jCRf80FFzvr+MpQeeoF4Xg==",
+ "dev": true,
+ "requires": {
+ "arr-union": "^3.1.0",
+ "get-value": "^2.0.6",
+ "is-extendable": "^0.1.1",
+ "set-value": "^2.0.1"
+ }
+ },
+ "unset-value": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/unset-value/-/unset-value-1.0.0.tgz",
+ "integrity": "sha1-g3aHP30jNRef+x5vw6jtDfyKtVk=",
+ "dev": true,
+ "requires": {
+ "has-value": "^0.3.1",
+ "isobject": "^3.0.0"
+ },
+ "dependencies": {
+ "has-value": {
+ "version": "0.3.1",
+ "resolved": "https://registry.npmjs.org/has-value/-/has-value-0.3.1.tgz",
+ "integrity": "sha1-ex9YutpiyoJ+wKIHgCVlSEWZXh8=",
+ "dev": true,
+ "requires": {
+ "get-value": "^2.0.3",
+ "has-values": "^0.1.4",
+ "isobject": "^2.0.0"
+ },
+ "dependencies": {
+ "isobject": {
+ "version": "2.1.0",
+ "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz",
+ "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=",
+ "dev": true,
+ "requires": {
+ "isarray": "1.0.0"
+ }
+ }
+ }
+ },
+ "has-values": {
+ "version": "0.1.4",
+ "resolved": "https://registry.npmjs.org/has-values/-/has-values-0.1.4.tgz",
+ "integrity": "sha1-bWHeldkd/Km5oCCJrThL/49it3E=",
+ "dev": true
+ }
+ }
+ },
+ "uri-js": {
+ "version": "4.2.2",
+ "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz",
+ "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==",
+ "dev": true,
+ "requires": {
+ "punycode": "^2.1.0"
+ }
+ },
+ "urix": {
+ "version": "0.1.0",
+ "resolved": "https://registry.npmjs.org/urix/-/urix-0.1.0.tgz",
+ "integrity": "sha1-2pN/emLiH+wf0Y1Js1wpNQZ6bHI=",
+ "dev": true
+ },
+ "use": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/use/-/use-3.1.1.tgz",
+ "integrity": "sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ==",
+ "dev": true
+ },
+ "util-deprecate": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz",
+ "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=",
+ "dev": true
+ },
+ "uuid": {
+ "version": "7.0.3",
+ "resolved": "https://registry.npmjs.org/uuid/-/uuid-7.0.3.tgz",
+ "integrity": "sha512-DPSke0pXhTZgoF/d+WSt2QaKMCFSfx7QegxEWT+JOuHF5aWrKEn0G+ztjuJg/gG8/ItK+rbPCD/yNv8yyih6Cg==",
+ "dev": true,
+ "optional": true
+ },
+ "v8-to-istanbul": {
+ "version": "4.1.4",
+ "resolved": "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-4.1.4.tgz",
+ "integrity": "sha512-Rw6vJHj1mbdK8edjR7+zuJrpDtKIgNdAvTSAcpYfgMIw+u2dPDntD3dgN4XQFLU2/fvFQdzj+EeSGfd/jnY5fQ==",
+ "dev": true,
+ "requires": {
+ "@types/istanbul-lib-coverage": "^2.0.1",
+ "convert-source-map": "^1.6.0",
+ "source-map": "^0.7.3"
+ },
+ "dependencies": {
+ "source-map": {
+ "version": "0.7.3",
+ "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.7.3.tgz",
+ "integrity": "sha512-CkCj6giN3S+n9qrYiBTX5gystlENnRW5jZeNLHpe6aue+SrHcG5VYwujhW9s4dY31mEGsxBDrHR6oI69fTXsaQ==",
+ "dev": true
+ }
+ }
+ },
+ "validate-npm-package-license": {
+ "version": "3.0.4",
+ "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz",
+ "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==",
+ "dev": true,
+ "requires": {
+ "spdx-correct": "^3.0.0",
+ "spdx-expression-parse": "^3.0.0"
+ }
+ },
+ "verror": {
+ "version": "1.10.0",
+ "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz",
+ "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=",
+ "dev": true,
+ "requires": {
+ "assert-plus": "^1.0.0",
+ "core-util-is": "1.0.2",
+ "extsprintf": "^1.2.0"
+ }
+ },
+ "w3c-hr-time": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/w3c-hr-time/-/w3c-hr-time-1.0.2.tgz",
+ "integrity": "sha512-z8P5DvDNjKDoFIHK7q8r8lackT6l+jo/Ye3HOle7l9nICP9lf1Ci25fy9vHd0JOWewkIFzXIEig3TdKT7JQ5fQ==",
+ "dev": true,
+ "requires": {
+ "browser-process-hrtime": "^1.0.0"
+ }
+ },
+ "w3c-xmlserializer": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/w3c-xmlserializer/-/w3c-xmlserializer-2.0.0.tgz",
+ "integrity": "sha512-4tzD0mF8iSiMiNs30BiLO3EpfGLZUT2MSX/G+o7ZywDzliWQ3OPtTZ0PTC3B3ca1UAf4cJMHB+2Bf56EriJuRA==",
+ "dev": true,
+ "requires": {
+ "xml-name-validator": "^3.0.0"
+ }
+ },
+ "walker": {
+ "version": "1.0.7",
+ "resolved": "https://registry.npmjs.org/walker/-/walker-1.0.7.tgz",
+ "integrity": "sha1-L3+bj9ENZ3JisYqITijRlhjgKPs=",
+ "dev": true,
+ "requires": {
+ "makeerror": "1.0.x"
+ }
+ },
+ "webidl-conversions": {
+ "version": "6.1.0",
+ "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-6.1.0.tgz",
+ "integrity": "sha512-qBIvFLGiBpLjfwmYAaHPXsn+ho5xZnGvyGvsarywGNc8VyQJUMHJ8OBKGGrPER0okBeMDaan4mNBlgBROxuI8w==",
+ "dev": true
+ },
+ "whatwg-encoding": {
+ "version": "1.0.5",
+ "resolved": "https://registry.npmjs.org/whatwg-encoding/-/whatwg-encoding-1.0.5.tgz",
+ "integrity": "sha512-b5lim54JOPN9HtzvK9HFXvBma/rnfFeqsic0hSpjtDbVxR3dJKLc+KB4V6GgiGOvl7CY/KNh8rxSo9DKQrnUEw==",
+ "dev": true,
+ "requires": {
+ "iconv-lite": "0.4.24"
+ }
+ },
+ "whatwg-mimetype": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmjs.org/whatwg-mimetype/-/whatwg-mimetype-2.3.0.tgz",
+ "integrity": "sha512-M4yMwr6mAnQz76TbJm914+gPpB/nCwvZbJU28cUD6dR004SAxDLOOSUaB1JDRqLtaOV/vi0IC5lEAGFgrjGv/g==",
+ "dev": true
+ },
+ "whatwg-url": {
+ "version": "8.1.0",
+ "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-8.1.0.tgz",
+ "integrity": "sha512-vEIkwNi9Hqt4TV9RdnaBPNt+E2Sgmo3gePebCRgZ1R7g6d23+53zCTnuB0amKI4AXq6VM8jj2DUAa0S1vjJxkw==",
+ "dev": true,
+ "requires": {
+ "lodash.sortby": "^4.7.0",
+ "tr46": "^2.0.2",
+ "webidl-conversions": "^5.0.0"
+ },
+ "dependencies": {
+ "webidl-conversions": {
+ "version": "5.0.0",
+ "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-5.0.0.tgz",
+ "integrity": "sha512-VlZwKPCkYKxQgeSbH5EyngOmRp7Ww7I9rQLERETtf5ofd9pGeswWiOtogpEO850jziPRarreGxn5QIiTqpb2wA==",
+ "dev": true
+ }
+ }
+ },
+ "which": {
+ "version": "2.0.2",
+ "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz",
+ "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==",
+ "dev": true,
+ "requires": {
+ "isexe": "^2.0.0"
+ }
+ },
+ "which-module": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz",
+ "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=",
+ "dev": true
+ },
+ "wide-align": {
+ "version": "1.1.3",
+ "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz",
+ "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==",
+ "dev": true,
+ "requires": {
+ "string-width": "^1.0.2 || 2"
+ }
+ },
+ "word-wrap": {
+ "version": "1.2.3",
+ "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz",
+ "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==",
+ "dev": true
+ },
+ "wrap-ansi": {
+ "version": "6.2.0",
+ "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-6.2.0.tgz",
+ "integrity": "sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA==",
+ "dev": true,
+ "requires": {
+ "ansi-styles": "^4.0.0",
+ "string-width": "^4.1.0",
+ "strip-ansi": "^6.0.0"
+ },
+ "dependencies": {
+ "is-fullwidth-code-point": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz",
+ "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==",
+ "dev": true
+ },
+ "string-width": {
+ "version": "4.2.0",
+ "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz",
+ "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==",
+ "dev": true,
+ "requires": {
+ "emoji-regex": "^8.0.0",
+ "is-fullwidth-code-point": "^3.0.0",
+ "strip-ansi": "^6.0.0"
+ }
+ },
+ "strip-ansi": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz",
+ "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==",
+ "dev": true,
+ "requires": {
+ "ansi-regex": "^5.0.0"
+ }
+ }
+ }
+ },
+ "wrappy": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz",
+ "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=",
+ "dev": true
+ },
+ "write-file-atomic": {
+ "version": "3.0.3",
+ "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-3.0.3.tgz",
+ "integrity": "sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q==",
+ "dev": true,
+ "requires": {
+ "imurmurhash": "^0.1.4",
+ "is-typedarray": "^1.0.0",
+ "signal-exit": "^3.0.2",
+ "typedarray-to-buffer": "^3.1.5"
+ }
+ },
+ "ws": {
+ "version": "7.3.1",
+ "resolved": "https://registry.npmjs.org/ws/-/ws-7.3.1.tgz",
+ "integrity": "sha512-D3RuNkynyHmEJIpD2qrgVkc9DQ23OrN/moAwZX4L8DfvszsJxpjQuUq3LMx6HoYji9fbIOBY18XWBsAux1ZZUA==",
+ "dev": true
+ },
+ "xml-name-validator": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/xml-name-validator/-/xml-name-validator-3.0.0.tgz",
+ "integrity": "sha512-A5CUptxDsvxKJEU3yO6DuWBSJz/qizqzJKOMIfUJHETbBw/sFaDxgd6fxm1ewUaM0jZ444Fc5vC5ROYurg/4Pw==",
+ "dev": true
+ },
+ "xmlchars": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/xmlchars/-/xmlchars-2.2.0.tgz",
+ "integrity": "sha512-JZnDKK8B0RCDw84FNdDAIpZK+JuJw+s7Lz8nksI7SIuU3UXJJslUthsi+uWBUYOwPFwW7W7PRLRfUKpxjtjFCw==",
+ "dev": true
+ },
+ "y18n": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.0.tgz",
+ "integrity": "sha512-r9S/ZyXu/Xu9q1tYlpsLIsa3EeLXXk0VwlxqTcFRfg9EhMW+17kbt9G0NrgCmhGb5vT2hyhJZLfDGx+7+5Uj/w==",
+ "dev": true
+ },
+ "yallist": {
+ "version": "3.1.1",
+ "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz",
+ "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==",
+ "dev": true
+ },
+ "yargs": {
+ "version": "15.4.1",
+ "resolved": "https://registry.npmjs.org/yargs/-/yargs-15.4.1.tgz",
+ "integrity": "sha512-aePbxDmcYW++PaqBsJ+HYUFwCdv4LVvdnhBy78E57PIor8/OVvhMrADFFEDh8DHDFRv/O9i3lPhsENjO7QX0+A==",
+ "dev": true,
+ "requires": {
+ "cliui": "^6.0.0",
+ "decamelize": "^1.2.0",
+ "find-up": "^4.1.0",
+ "get-caller-file": "^2.0.1",
+ "require-directory": "^2.1.1",
+ "require-main-filename": "^2.0.0",
+ "set-blocking": "^2.0.0",
+ "string-width": "^4.2.0",
+ "which-module": "^2.0.0",
+ "y18n": "^4.0.0",
+ "yargs-parser": "^18.1.2"
+ },
+ "dependencies": {
+ "is-fullwidth-code-point": {
+ "version": "3.0.0",
+ "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz",
+ "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==",
+ "dev": true
+ },
+ "string-width": {
+ "version": "4.2.0",
+ "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz",
+ "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==",
+ "dev": true,
+ "requires": {
+ "emoji-regex": "^8.0.0",
+ "is-fullwidth-code-point": "^3.0.0",
+ "strip-ansi": "^6.0.0"
+ }
+ },
+ "strip-ansi": {
+ "version": "6.0.0",
+ "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz",
+ "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==",
+ "dev": true,
+ "requires": {
+ "ansi-regex": "^5.0.0"
+ }
+ }
+ }
+ },
+ "yargs-parser": {
+ "version": "18.1.3",
+ "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-18.1.3.tgz",
+ "integrity": "sha512-o50j0JeToy/4K6OZcaQmW6lyXXKhq7csREXcDwk2omFPJEwUNOVtJKvmDr9EI1fAJZUyZcRF7kxGBWmRXudrCQ==",
+ "dev": true,
+ "requires": {
+ "camelcase": "^5.0.0",
+ "decamelize": "^1.2.0"
+ }
}
}
}
diff --git a/src/Kernel/package.json b/src/Kernel/package.json
index cbafb82936..ec685073ec 100644
--- a/src/Kernel/package.json
+++ b/src/Kernel/package.json
@@ -1,5 +1,22 @@
{
+ "scripts": {
+ "test": "jest"
+ },
"devDependencies": {
- "@types/codemirror": "0.0.56"
+ "@types/codemirror": "0.0.56",
+ "@types/jest": "^26.0.4",
+ "canvas": "^2.6.1",
+ "jest": "^26.1.0",
+ "ts-jest": "^26.1.2",
+ "typescript": "^3.9.6"
+ },
+ "jest": {
+ "transform": {
+ "^.+\\.tsx?$": "ts-jest"
+ },
+ "moduleFileExtensions": [
+ "ts",
+ "js"
+ ]
}
}
diff --git a/src/Kernel/tsconfig.json b/src/Kernel/tsconfig.json
index 14c6ecc0d4..40cbbba7c9 100644
--- a/src/Kernel/tsconfig.json
+++ b/src/Kernel/tsconfig.json
@@ -8,9 +8,10 @@
"baseUrl": ".",
"outDir": "res",
"outFile": "res/bundle.js",
- "lib": [ "DOM", "ES2015" ],
- "module": "AMD"
+ "lib": [ "DOM", "ES2019" ],
+ "module": "AMD",
+ "moduleResolution": "node"
},
- "exclude": ["node_modules", "wwwroot"],
+ "exclude": ["node_modules", "wwwroot", "client/__tests__"],
"include": ["client/**/*"]
}
diff --git a/src/Mock.Chemistry/Library.qs b/src/MockLibraries/Mock.Chemistry/Library.qs
similarity index 99%
rename from src/Mock.Chemistry/Library.qs
rename to src/MockLibraries/Mock.Chemistry/Library.qs
index 1f95182e28..247eea5d79 100644
--- a/src/Mock.Chemistry/Library.qs
+++ b/src/MockLibraries/Mock.Chemistry/Library.qs
@@ -1,7 +1,6 @@
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
-
//
// These are mock classes that resemble the data structures defined in the chemistry library
//
@@ -9,7 +8,6 @@ namespace Mock.Chemistry {
open Microsoft.Quantum.Intrinsic;
open Microsoft.Quantum.Canon;
-
/// # Summary
/// Format of data passed from C# to Q# to represent a term of the Hamiltonian.
/// The meaning of the data represented is determined by the algorithm that receives it.
diff --git a/src/Mock.Chemistry/Mock.Chemistry.csproj b/src/MockLibraries/Mock.Chemistry/Mock.Chemistry.csproj
similarity index 79%
rename from src/Mock.Chemistry/Mock.Chemistry.csproj
rename to src/MockLibraries/Mock.Chemistry/Mock.Chemistry.csproj
index b8b345ce83..7900c48c47 100644
--- a/src/Mock.Chemistry/Mock.Chemistry.csproj
+++ b/src/MockLibraries/Mock.Chemistry/Mock.Chemistry.csproj
@@ -1,4 +1,4 @@
-
+
netstandard2.1
@@ -6,6 +6,6 @@
-
+
diff --git a/src/MockLibraries/Mock.Standard/Arrays.cs b/src/MockLibraries/Mock.Standard/Arrays.cs
new file mode 100644
index 0000000000..c3e930e07b
--- /dev/null
+++ b/src/MockLibraries/Mock.Standard/Arrays.cs
@@ -0,0 +1,19 @@
+// Copyright (c) Microsoft Corporation.
+// Licensed under the MIT License.
+
+using Microsoft.Quantum.Simulation.Core;
+using System;
+
+namespace Mock.Standard
+{
+ public partial class ForEach<__T__, __U__>
+ {
+ public override RuntimeMetadata GetRuntimeMetadata(IApplyData args)
+ {
+ var metadata = base.GetRuntimeMetadata(args);
+ if (metadata == null) throw new NullReferenceException($"Null RuntimeMetadata found for {this.ToString()}.");
+ metadata.IsComposite = true;
+ return metadata;
+ }
+ }
+}
diff --git a/src/MockLibraries/Mock.Standard/Arrays.qs b/src/MockLibraries/Mock.Standard/Arrays.qs
new file mode 100644
index 0000000000..4971810eab
--- /dev/null
+++ b/src/MockLibraries/Mock.Standard/Arrays.qs
@@ -0,0 +1,43 @@
+// Copyright (c) Microsoft Corporation. All rights reserved.
+// Licensed under the MIT License.
+
+//
+// These are mock classes that resemble the data structures defined in the Microsoft.Quantum.Arrays library
+//
+namespace Mock.Standard {
+ open Microsoft.Quantum.Arrays;
+
+ /// # Summary
+ /// Given an array and an operation that is defined
+ /// for the elements of the array, returns a new array that consists
+ /// of the images of the original array under the operation.
+ ///
+ /// # Remarks
+ /// The operation is defined for generic types, i.e., whenever we have
+ /// an array `'T[]` and an operation `action : 'T -> 'U` we can map the elements
+ /// of the array and produce a new array of type `'U[]`.
+ ///
+ /// # Type Parameters
+ /// ## 'T
+ /// The type of `array` elements.
+ /// ## 'U
+ /// The result type of the `action` operation.
+ ///
+ /// # Input
+ /// ## action
+ /// An operation from `'T` to `'U` that is applied to each element.
+ /// ## array
+ /// An array of elements over `'T`.
+ ///
+ /// # Output
+ /// An array `'U[]` of elements that are mapped by the `action` operation.
+ operation ForEach<'T, 'U> (action : ('T => 'U), array : 'T[]) : 'U[] {
+ mutable resultArray = new 'U[Length(array)];
+
+ for (idxElement in IndexRange(array)) {
+ set resultArray w/= idxElement <- action(array[idxElement]);
+ }
+
+ return resultArray;
+ }
+}
diff --git a/src/MockLibraries/Mock.Standard/Canon.cs b/src/MockLibraries/Mock.Standard/Canon.cs
new file mode 100644
index 0000000000..3d28a19152
--- /dev/null
+++ b/src/MockLibraries/Mock.Standard/Canon.cs
@@ -0,0 +1,19 @@
+// Copyright (c) Microsoft Corporation.
+// Licensed under the MIT License.
+
+using Microsoft.Quantum.Simulation.Core;
+using System;
+
+namespace Mock.Standard
+{
+ public partial class ApplyToEach<__T__>
+ {
+ public override RuntimeMetadata GetRuntimeMetadata(IApplyData args)
+ {
+ var metadata = base.GetRuntimeMetadata(args);
+ if (metadata == null) throw new NullReferenceException($"Null RuntimeMetadata found for {this.ToString()}.");
+ metadata.IsComposite = true;
+ return metadata;
+ }
+ }
+}
diff --git a/src/MockLibraries/Mock.Standard/Canon.qs b/src/MockLibraries/Mock.Standard/Canon.qs
new file mode 100644
index 0000000000..2037f2c618
--- /dev/null
+++ b/src/MockLibraries/Mock.Standard/Canon.qs
@@ -0,0 +1,43 @@
+// Copyright (c) Microsoft Corporation. All rights reserved.
+// Licensed under the MIT License.
+
+//
+// These are mock classes that resemble the data structures defined in the Microsoft.Quantum.Canon library
+//
+namespace Mock.Standard {
+ open Microsoft.Quantum.Arrays;
+
+ /// # Summary
+ /// Applies a single-qubit operation to each element in a register.
+ ///
+ /// # Input
+ /// ## singleElementOperation
+ /// Operation to apply to each qubit.
+ /// ## register
+ /// Array of qubits on which to apply the given operation.
+ ///
+ /// # Type Parameters
+ /// ## 'T
+ /// The target on which the operation acts.
+ ///
+ /// # Remarks
+ /// ## Example
+ /// Prepare a three-qubit $\ket{+}$ state:
+ /// ```qsharp
+ /// using (register = Qubit[3]) {
+ /// ApplyToEach(H, register);
+ /// }
+ /// ```
+ ///
+ /// # See Also
+ /// - Microsoft.Quantum.Canon.ApplyToEachC
+ /// - Microsoft.Quantum.Canon.ApplyToEachA
+ /// - Microsoft.Quantum.Canon.ApplyToEachCA
+ operation ApplyToEach<'T> (singleElementOperation : ('T => Unit), register : 'T[]) : Unit
+ {
+ for (idxQubit in IndexRange(register))
+ {
+ singleElementOperation(register[idxQubit]);
+ }
+ }
+}
diff --git a/src/MockLibraries/Mock.Standard/Mock.Standard.csproj b/src/MockLibraries/Mock.Standard/Mock.Standard.csproj
new file mode 100644
index 0000000000..7900c48c47
--- /dev/null
+++ b/src/MockLibraries/Mock.Standard/Mock.Standard.csproj
@@ -0,0 +1,11 @@
+
+
+
+ netstandard2.1
+ false
+
+
+
+
+
+
diff --git a/src/Tests/ExecutionPathTracerTests.cs b/src/Tests/ExecutionPathTracerTests.cs
new file mode 100644
index 0000000000..ffd70d71a1
--- /dev/null
+++ b/src/Tests/ExecutionPathTracerTests.cs
@@ -0,0 +1,769 @@
+// Copyright (c) Microsoft Corporation. All rights reserved.
+// Licensed under the MIT License.
+
+using System.Collections.Generic;
+using System.Linq;
+
+using Microsoft.Quantum.IQSharp;
+using Microsoft.Quantum.IQSharp.Core.ExecutionPathTracer;
+using Microsoft.Quantum.Simulation.Simulators;
+using Microsoft.VisualStudio.TestTools.UnitTesting;
+
+namespace Tests.IQSharp
+{
+ public class ExecutionPathTracerTests
+ {
+ public Workspace InitWorkspace()
+ {
+ var ws = Startup.Create("Workspace.ExecutionPathTracer");
+ ws.GlobalReferences.AddPackage("mock.standard").Wait();
+ ws.Reload();
+ Assert.IsFalse(ws.HasErrors);
+ return ws;
+ }
+
+ public ExecutionPath GetExecutionPath(string name, int depth = 1)
+ {
+ var ws = InitWorkspace();
+ var op = ws.AssemblyInfo.Operations.SingleOrDefault(o => o.FullName == $"Tests.ExecutionPathTracer.{name}");
+ Assert.IsNotNull(op);
+
+ var tracer = new ExecutionPathTracer(depth);
+ using var qsim = new QuantumSimulator().WithExecutionPathTracer(tracer);
+ op.RunAsync(qsim, new Dictionary()).Wait();
+
+ return tracer.GetExecutionPath();
+ }
+ }
+
+ [TestClass]
+ public class IntrinsicTests : ExecutionPathTracerTests
+ {
+ [TestMethod]
+ public void HTest()
+ {
+ var path = GetExecutionPath("HCirc");
+ var qubits = new QubitDeclaration[]
+ {
+ new QubitDeclaration(0),
+ };
+ var operations = new Operation[]
+ {
+ new Operation()
+ {
+ Gate = "H",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ new Operation()
+ {
+ Gate = "Reset",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ };
+ var expected = new ExecutionPath(qubits, operations);
+ Assert.AreEqual(expected.ToJson(), path.ToJson());
+ }
+
+ [TestMethod]
+ public void MTest()
+ {
+ var path = GetExecutionPath("MCirc");
+ var qubits = new QubitDeclaration[]
+ {
+ new QubitDeclaration(0, 1),
+ };
+ var operations = new Operation[]
+ {
+ new Operation()
+ {
+ Gate = "M",
+ IsMeasurement = true,
+ Controls = new List() { new QubitRegister(0) },
+ Targets = new List() { new ClassicalRegister(0, 0) },
+ },
+ };
+ var expected = new ExecutionPath(qubits, operations);
+ Assert.AreEqual(expected.ToJson(), path.ToJson());
+ }
+
+ [TestMethod]
+ public void CnotTest()
+ {
+ var path = GetExecutionPath("CnotCirc");
+ var qubits = new QubitDeclaration[]
+ {
+ new QubitDeclaration(0),
+ new QubitDeclaration(1),
+ };
+ var operations = new Operation[]
+ {
+ new Operation()
+ {
+ Gate = "X",
+ IsControlled = true,
+ Controls = new List() { new QubitRegister(0) },
+ Targets = new List() { new QubitRegister(1) },
+ },
+ new Operation()
+ {
+ Gate = "Reset",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ new Operation()
+ {
+ Gate = "Reset",
+ Targets = new List() { new QubitRegister(1) },
+ },
+ };
+ var expected = new ExecutionPath(qubits, operations);
+ Assert.AreEqual(expected.ToJson(), path.ToJson());
+ }
+
+ [TestMethod]
+ public void CcnotTest()
+ {
+ var path = GetExecutionPath("CcnotCirc");
+ var qubits = new QubitDeclaration[]
+ {
+ new QubitDeclaration(0),
+ new QubitDeclaration(1),
+ new QubitDeclaration(2),
+ };
+ var operations = new Operation[]
+ {
+ new Operation()
+ {
+ Gate = "X",
+ IsControlled = true,
+ Controls = new List() { new QubitRegister(0), new QubitRegister(2) },
+ Targets = new List() { new QubitRegister(1) },
+ },
+ new Operation()
+ {
+ Gate = "Reset",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ new Operation()
+ {
+ Gate = "Reset",
+ Targets = new List() { new QubitRegister(1) },
+ },
+ new Operation()
+ {
+ Gate = "Reset",
+ Targets = new List() { new QubitRegister(2) },
+ },
+ };
+ var expected = new ExecutionPath(qubits, operations);
+ Assert.AreEqual(expected.ToJson(), path.ToJson());
+ }
+
+ [TestMethod]
+ public void SwapTest()
+ {
+ var path = GetExecutionPath("SwapCirc");
+ var qubits = new QubitDeclaration[]
+ {
+ new QubitDeclaration(0),
+ new QubitDeclaration(1),
+ };
+ var operations = new Operation[]
+ {
+ new Operation()
+ {
+ Gate = "SWAP",
+ Targets = new List() { new QubitRegister(0), new QubitRegister(1) },
+ },
+ };
+ var expected = new ExecutionPath(qubits, operations);
+ Assert.AreEqual(expected.ToJson(), path.ToJson());
+ }
+
+ [TestMethod]
+ public void RxTest()
+ {
+ var path = GetExecutionPath("RxCirc");
+ var qubits = new QubitDeclaration[]
+ {
+ new QubitDeclaration(0),
+ };
+ var operations = new Operation[]
+ {
+ new Operation()
+ {
+ Gate = "Rx",
+ DisplayArgs = "(2)",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ new Operation()
+ {
+ Gate = "Reset",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ };
+ var expected = new ExecutionPath(qubits, operations);
+ Assert.AreEqual(expected.ToJson(), path.ToJson());
+ }
+
+ [TestMethod]
+ public void AdjointHTest()
+ {
+ var path = GetExecutionPath("AdjointHCirc");
+ var qubits = new QubitDeclaration[]
+ {
+ new QubitDeclaration(0),
+ };
+ var operations = new Operation[]
+ {
+ new Operation()
+ {
+ Gate = "H",
+ IsAdjoint = true,
+ Targets = new List() { new QubitRegister(0) },
+ },
+ new Operation()
+ {
+ Gate = "Reset",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ };
+ var expected = new ExecutionPath(qubits, operations);
+ Assert.AreEqual(expected.ToJson(), path.ToJson());
+ }
+
+ [TestMethod]
+ public void ControlledXTest()
+ {
+ var path = GetExecutionPath("ControlledXCirc");
+ var qubits = new QubitDeclaration[]
+ {
+ new QubitDeclaration(0),
+ new QubitDeclaration(1),
+ };
+ var operations = new Operation[]
+ {
+ new Operation()
+ {
+ Gate = "X",
+ IsControlled = true,
+ Controls = new List() { new QubitRegister(0) },
+ Targets = new List() { new QubitRegister(1) },
+ },
+ new Operation()
+ {
+ Gate = "Reset",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ new Operation()
+ {
+ Gate = "Reset",
+ Targets = new List() { new QubitRegister(1) },
+ },
+ };
+ var expected = new ExecutionPath(qubits, operations);
+ Assert.AreEqual(expected.ToJson(), path.ToJson());
+
+ // JSON should be the same as CNOT's
+ var path2 = GetExecutionPath("CnotCirc");
+ Assert.AreEqual(path.ToJson(), path2.ToJson());
+ }
+
+ [TestMethod]
+ public void ControlledAdjointSTest()
+ {
+ var path = GetExecutionPath("ControlledAdjointSCirc");
+ var qubits = new QubitDeclaration[]
+ {
+ new QubitDeclaration(0),
+ new QubitDeclaration(1),
+ };
+ var operations = new Operation[]
+ {
+ new Operation()
+ {
+ Gate = "S",
+ IsControlled = true,
+ IsAdjoint = true,
+ Controls = new List() { new QubitRegister(0) },
+ Targets = new List() { new QubitRegister(1) },
+ },
+ new Operation()
+ {
+ Gate = "Reset",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ new Operation()
+ {
+ Gate = "Reset",
+ Targets = new List() { new QubitRegister(1) },
+ },
+ };
+ var expected = new ExecutionPath(qubits, operations);
+ Assert.AreEqual(expected.ToJson(), path.ToJson());
+ }
+ }
+
+ [TestClass]
+ public class Circuits : ExecutionPathTracerTests
+ {
+ [TestMethod]
+ public void FooTest()
+ {
+ var path = GetExecutionPath("FooCirc");
+ var qubits = new QubitDeclaration[]
+ {
+ new QubitDeclaration(0),
+ };
+ var operations = new Operation[]
+ {
+ new Operation()
+ {
+ Gate = "Foo",
+ DisplayArgs = "(2.1, (\"bar\"))",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ };
+ var expected = new ExecutionPath(qubits, operations);
+ Assert.AreEqual(expected.ToJson(), path.ToJson());
+ }
+
+ [TestMethod]
+ public void ControlledFooTest()
+ {
+ var path = GetExecutionPath("ControlledFooCirc");
+ var qubits = new QubitDeclaration[]
+ {
+ new QubitDeclaration(0),
+ new QubitDeclaration(1),
+ };
+ var operations = new Operation[]
+ {
+ new Operation()
+ {
+ Gate = "Foo",
+ DisplayArgs = "(2.1, (\"bar\"))",
+ IsControlled = true,
+ Controls = new List() { new QubitRegister(0) },
+ Targets = new List() { new QubitRegister(1) },
+ },
+ };
+ var expected = new ExecutionPath(qubits, operations);
+ Assert.AreEqual(expected.ToJson(), path.ToJson());
+ }
+
+ [TestMethod]
+ public void UnusedQubitTest()
+ {
+ var path = GetExecutionPath("UnusedQubitCirc");
+ var qubits = new QubitDeclaration[]
+ {
+ new QubitDeclaration(0),
+ new QubitDeclaration(2),
+ };
+ var operations = new Operation[]
+ {
+ new Operation()
+ {
+ Gate = "X",
+ IsControlled = true,
+ Controls = new List() { new QubitRegister(2) },
+ Targets = new List() { new QubitRegister(0) },
+ },
+ new Operation()
+ {
+ Gate = "Reset",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ new Operation()
+ {
+ Gate = "Reset",
+ Targets = new List() { new QubitRegister(2) },
+ },
+ };
+ var expected = new ExecutionPath(qubits, operations);
+ Assert.AreEqual(expected.ToJson(), path.ToJson());
+ }
+
+ [TestMethod]
+ public void Depth2Test()
+ {
+ var path = GetExecutionPath("Depth2Circ", 2);
+ var qubits = new QubitDeclaration[] { new QubitDeclaration(0) };
+ var operations = new Operation[]
+ {
+ new Operation()
+ {
+ Gate = "H",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ new Operation()
+ {
+ Gate = "X",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ new Operation()
+ {
+ Gate = "H",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ };
+ var expected = new ExecutionPath(qubits, operations);
+ Assert.AreEqual(expected.ToJson(), path.ToJson());
+ }
+
+ [TestMethod]
+ public void PartialOpTest()
+ {
+ var path = GetExecutionPath("PartialOpCirc");
+ var qubits = new QubitDeclaration[]
+ {
+ new QubitDeclaration(0),
+ new QubitDeclaration(1),
+ new QubitDeclaration(2),
+ };
+ var operations = new Operation[]
+ {
+ new Operation()
+ {
+ Gate = "H",
+ IsControlled = true,
+ Controls = new List() { new QubitRegister(0), new QubitRegister(1) },
+ Targets = new List() { new QubitRegister(2) },
+ },
+ new Operation()
+ {
+ Gate = "Ry",
+ DisplayArgs = "(2.5)",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ new Operation()
+ {
+ Gate = "Reset",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ new Operation()
+ {
+ Gate = "Reset",
+ Targets = new List() { new QubitRegister(1) },
+ },
+ new Operation()
+ {
+ Gate = "Reset",
+ Targets = new List() { new QubitRegister(2) },
+ },
+ };
+ var expected = new ExecutionPath(qubits, operations);
+ Assert.AreEqual(expected.ToJson(), path.ToJson());
+ }
+
+ [TestMethod]
+ public void EmptyTest()
+ {
+ var path = GetExecutionPath("EmptyCirc");
+ var qubits = new QubitDeclaration[] { };
+ var operations = new Operation[] {
+ new Operation()
+ {
+ Gate = "EmptyCirc",
+ },
+ };
+ var expected = new ExecutionPath(qubits, operations);
+ Assert.AreEqual(expected.ToJson(), path.ToJson());
+ }
+
+ [TestMethod]
+ public void NoQubitArgsTest()
+ {
+ var path = GetExecutionPath("NoQubitArgsCirc");
+ var qubits = new QubitDeclaration[] { };
+ var operations = new Operation[]
+ {
+ new Operation()
+ {
+ Gate = "NoQubitCirc",
+ DisplayArgs = "(2)",
+ },
+ };
+ var expected = new ExecutionPath(qubits, operations);
+ Assert.AreEqual(expected.ToJson(), path.ToJson());
+ }
+
+ [TestMethod]
+ public void OperationArgsTest()
+ {
+ var path = GetExecutionPath("OperationArgsCirc");
+ var qubits = new QubitDeclaration[] { };
+ var operations = new Operation[]
+ {
+ new Operation()
+ {
+ Gate = "OperationCirc",
+ DisplayArgs = "(H, 5)",
+ },
+ };
+ var expected = new ExecutionPath(qubits, operations);
+ Assert.AreEqual(expected.ToJson(), path.ToJson());
+ }
+
+ [TestMethod]
+ public void NestedTest()
+ {
+ var path = GetExecutionPath("NestedCirc");
+ var qubits = new QubitDeclaration[] { new QubitDeclaration(0) };
+ var operations = new Operation[]
+ {
+ new Operation()
+ {
+ Gate = "H",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ new Operation()
+ {
+ Gate = "HCirc",
+ },
+ new Operation()
+ {
+ Gate = "Reset",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ };
+ var expected = new ExecutionPath(qubits, operations);
+ Assert.AreEqual(expected.ToJson(), path.ToJson());
+ }
+
+ [TestMethod]
+ public void BigTest()
+ {
+ var path = GetExecutionPath("BigCirc");
+ var qubits = new QubitDeclaration[]
+ {
+ new QubitDeclaration(0, 1),
+ new QubitDeclaration(1),
+ new QubitDeclaration(2),
+ };
+ var operations = new Operation[]
+ {
+ new Operation()
+ {
+ Gate = "H",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ new Operation()
+ {
+ Gate = "Ry",
+ DisplayArgs = "(2.5)",
+ Targets = new List() { new QubitRegister(1) },
+ },
+ new Operation()
+ {
+ Gate = "Bar",
+ DisplayArgs = "((1, 2.1), (\"foo\"))",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ new Operation()
+ {
+ Gate = "X",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ new Operation()
+ {
+ Gate = "X",
+ IsControlled = true,
+ Controls = new List() { new QubitRegister(0), new QubitRegister(1) },
+ Targets = new List() { new QubitRegister(2) },
+ },
+ new Operation()
+ {
+ Gate = "X",
+ IsControlled = true,
+ Controls = new List() { new QubitRegister(0), new QubitRegister(1) },
+ Targets = new List() { new QubitRegister(2) },
+ },
+ new Operation()
+ {
+ Gate = "Bar",
+ DisplayArgs = "((1, 2.1), (\"foo\"))",
+ IsControlled = true,
+ IsAdjoint = true,
+ Controls = new List() { new QubitRegister(2) },
+ Targets = new List() { new QubitRegister(0) },
+ },
+ new Operation()
+ {
+ Gate = "M",
+ IsMeasurement = true,
+ Controls = new List() { new QubitRegister(0) },
+ Targets = new List() { new ClassicalRegister(0, 0) },
+ },
+ new Operation()
+ {
+ Gate = "Reset",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ new Operation()
+ {
+ Gate = "Reset",
+ Targets = new List() { new QubitRegister(1) },
+ },
+ new Operation()
+ {
+ Gate = "Reset",
+ Targets = new List() { new QubitRegister(2) },
+ },
+ };
+ var expected = new ExecutionPath(qubits, operations);
+ Assert.AreEqual(expected.ToJson(), path.ToJson());
+ }
+ }
+
+ [TestClass]
+ public class CanonTests : ExecutionPathTracerTests
+ {
+ [TestMethod]
+ public void ApplyToEachTest()
+ {
+ var path = GetExecutionPath("ApplyToEachCirc");
+ var qubits = new QubitDeclaration[]
+ {
+ new QubitDeclaration(0),
+ new QubitDeclaration(1),
+ new QubitDeclaration(2),
+ };
+ var operations = new Operation[]
+ {
+ new Operation()
+ {
+ Gate = "H",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ new Operation()
+ {
+ Gate = "H",
+ Targets = new List() { new QubitRegister(1) },
+ },
+ new Operation()
+ {
+ Gate = "H",
+ Targets = new List() { new QubitRegister(2) },
+ },
+ new Operation()
+ {
+ Gate = "Reset",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ new Operation()
+ {
+ Gate = "Reset",
+ Targets = new List() { new QubitRegister(1) },
+ },
+ new Operation()
+ {
+ Gate = "Reset",
+ Targets = new List() { new QubitRegister(2) },
+ },
+ };
+ var expected = new ExecutionPath(qubits, operations);
+ Assert.AreEqual(expected.ToJson(), path.ToJson());
+ }
+ }
+
+ [TestClass]
+ public class MeasurementTests : ExecutionPathTracerTests
+ {
+ [TestMethod]
+ public void MResetXTest()
+ {
+ var path = GetExecutionPath("MResetXCirc");
+ var qubits = new QubitDeclaration[]
+ {
+ new QubitDeclaration(0, 1),
+ };
+ var operations = new Operation[]
+ {
+ new Operation()
+ {
+ Gate = "MResetX",
+ IsMeasurement = true,
+ Controls = new List() { new QubitRegister(0) },
+ Targets = new List() { new ClassicalRegister(0, 0) },
+ },
+ };
+ var expected = new ExecutionPath(qubits, operations);
+ Assert.AreEqual(expected.ToJson(), path.ToJson());
+ }
+
+ [TestMethod]
+ public void MResetYTest()
+ {
+ var path = GetExecutionPath("MResetYCirc");
+ var qubits = new QubitDeclaration[]
+ {
+ new QubitDeclaration(0, 1),
+ };
+ var operations = new Operation[]
+ {
+ new Operation()
+ {
+ Gate = "MResetY",
+ IsMeasurement = true,
+ Controls = new List() { new QubitRegister(0) },
+ Targets = new List() { new ClassicalRegister(0, 0) },
+ },
+ };
+ var expected = new ExecutionPath(qubits, operations);
+ Assert.AreEqual(expected.ToJson(), path.ToJson());
+ }
+
+ [TestMethod]
+ public void MResetZTest()
+ {
+ var path = GetExecutionPath("MResetZCirc");
+ var qubits = new QubitDeclaration[]
+ {
+ new QubitDeclaration(0, 1),
+ };
+ var operations = new Operation[]
+ {
+ new Operation()
+ {
+ Gate = "MResetZ",
+ IsMeasurement = true,
+ Controls = new List() { new QubitRegister(0) },
+ Targets = new List() { new ClassicalRegister(0, 0) },
+ },
+ };
+ var expected = new ExecutionPath(qubits, operations);
+ Assert.AreEqual(expected.ToJson(), path.ToJson());
+ }
+
+ [TestMethod]
+ public void ForEachMeasureCirc()
+ {
+ var path = GetExecutionPath("ForEachMeasureCirc");
+ var qubits = new QubitDeclaration[]
+ {
+ new QubitDeclaration(0, 1),
+ new QubitDeclaration(1, 1),
+ };
+ var operations = new Operation[]
+ {
+ new Operation()
+ {
+ Gate = "MResetZ",
+ IsMeasurement = true,
+ Controls = new List() { new QubitRegister(0) },
+ Targets = new List() { new ClassicalRegister(0, 0) },
+ },
+ new Operation()
+ {
+ Gate = "MResetZ",
+ IsMeasurement = true,
+ Controls = new List() { new QubitRegister(1) },
+ Targets = new List() { new ClassicalRegister(1, 0) },
+ },
+ };
+ var expected = new ExecutionPath(qubits, operations);
+ Assert.AreEqual(expected.ToJson(), path.ToJson());
+ }
+ }
+}
diff --git a/src/Tests/IQsharpEngineTests.cs b/src/Tests/IQsharpEngineTests.cs
index 8d9a3cc039..7252c893fb 100644
--- a/src/Tests/IQsharpEngineTests.cs
+++ b/src/Tests/IQsharpEngineTests.cs
@@ -10,12 +10,11 @@
using Microsoft.Quantum.IQSharp;
using Microsoft.Quantum.IQSharp.Jupyter;
using Microsoft.Quantum.IQSharp.Kernel;
-using Microsoft.Quantum.Simulation.Core;
+using Microsoft.Quantum.IQSharp.Core.ExecutionPathTracer;
using Microsoft.VisualStudio.TestTools.UnitTesting;
using Newtonsoft.Json;
using System.Data;
-using Microsoft.Quantum.IQSharp.AzureClient;
#pragma warning disable VSTHRD200 // Use "Async" suffix for async methods
@@ -86,6 +85,44 @@ public static async Task AssertEstimate(IQSharpEngine engine, string sni
return response.Output?.ToString();
}
+ private async Task AssertTrace(string name, ExecutionPath expectedPath)
+ {
+ var engine = Init("Workspace.ExecutionPathTracer");
+ var snippets = engine.Snippets as Snippets;
+ var configSource = new ConfigurationSource(skipLoading: true);
+
+ var wsMagic = new WorkspaceMagic(snippets.Workspace);
+ var pkgMagic = new PackageMagic(snippets.GlobalReferences);
+ var traceMagic = new TraceMagic(engine.SymbolsResolver, configSource);
+
+ var channel = new MockChannel();
+
+ // Add dependencies:
+ var response = await pkgMagic.Execute("mock.standard", channel);
+ PrintResult(response, channel);
+ Assert.AreEqual(ExecuteStatus.Ok, response.Status);
+
+ // Reload workspace:
+ response = await wsMagic.Execute("reload", channel);
+ PrintResult(response, channel);
+ Assert.AreEqual(ExecuteStatus.Ok, response.Status);
+
+ response = await traceMagic.Execute(name, channel);
+ PrintResult(response, channel);
+ Assert.AreEqual(ExecuteStatus.Ok, response.Status);
+
+ var message = channel.iopubMessages.ElementAtOrDefault(0);
+ Assert.IsNotNull(message);
+ Assert.AreEqual("render_execution_path", message.Header.MessageType);
+
+ var content = message.Content as ExecutionPathVisualizerContent;
+ Assert.IsNotNull(content);
+
+ var path = content.ExecutionPath.ToObject();
+ Assert.IsNotNull(path);
+ Assert.AreEqual(expectedPath.ToJson(), path.ToJson());
+ }
+
[TestMethod]
public async Task CompileOne()
{
@@ -282,7 +319,7 @@ public async Task TestPackages()
{
var engine = Init();
var snippets = engine.Snippets as Snippets;
-
+
var pkgMagic = new PackageMagic(snippets.GlobalReferences);
var channel = new MockChannel();
var response = await pkgMagic.Execute("", channel);
@@ -478,6 +515,68 @@ public void TestResolveMagic()
Assert.IsNotNull(resolver.Resolve("%azure.output"));
Assert.IsNotNull(resolver.Resolve("%azure.jobs"));
}
+
+ [TestMethod]
+ public async Task TestTraceMagic()
+ {
+ await AssertTrace("HCirc", new ExecutionPath(
+ new QubitDeclaration[] { new QubitDeclaration(0) },
+ new Operation[]
+ {
+ new Operation()
+ {
+ Gate = "H",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ new Operation()
+ {
+ Gate = "Reset",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ }
+ ));
+
+ // Should only see depth-1 operations
+ await AssertTrace("Depth2Circ", new ExecutionPath(
+ new QubitDeclaration[] { new QubitDeclaration(0) },
+ new Operation[]
+ {
+ new Operation()
+ {
+ Gate = "FooBar",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ new Operation()
+ {
+ Gate = "H",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ }
+ ));
+
+ // Should see depth-2 operations
+ await AssertTrace("Depth2Circ --depth=2", new ExecutionPath(
+ new QubitDeclaration[] { new QubitDeclaration(0) },
+ new Operation[]
+ {
+ new Operation()
+ {
+ Gate = "H",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ new Operation()
+ {
+ Gate = "X",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ new Operation()
+ {
+ Gate = "H",
+ Targets = new List() { new QubitRegister(0) },
+ },
+ }
+ ));
+ }
}
}
#pragma warning restore VSTHRD200 // Use "Async" suffix for async methods
diff --git a/src/Tests/Mocks.cs b/src/Tests/Mocks.cs
index b071b6abc6..9485061eb9 100644
--- a/src/Tests/Mocks.cs
+++ b/src/Tests/Mocks.cs
@@ -110,6 +110,7 @@ public class MockChannel : IChannel
{
public List errors = new List();
public List msgs = new List();
+ public List iopubMessages = new List();
public void Display(object displayable)
{
@@ -121,6 +122,8 @@ public IUpdatableDisplay DisplayUpdatable(object displayable)
return new MockUpdatableDisplay();
}
+ public void SendIoPubMessage(Message message) => iopubMessages.Add(message);
+
public void Stderr(string message) => errors.Add(message);
public void Stdout(string message) => msgs.Add(message);
@@ -138,6 +141,8 @@ public class MockNugetPackages : INugetPackages
{
private static readonly AssemblyInfo MockChemistryAssembly = new AssemblyInfo(typeof(Mock.Chemistry.JordanWignerEncodingData).Assembly);
+ private static readonly AssemblyInfo MockStandardAssembly = new AssemblyInfo(typeof(Mock.Standard.ApplyToEach).Assembly);
+
List _items = new List();
public IEnumerable Items => _items;
@@ -146,10 +151,15 @@ public IEnumerable Assemblies
{
get
{
- if (_items.Select(p => p.Id).Contains("mock.chemistry"))
+ var packageIds = _items.Select(p => p.Id);
+ if (packageIds.Contains("mock.chemistry"))
{
yield return MockChemistryAssembly;
}
+ else if (packageIds.Contains("mock.standard"))
+ {
+ yield return MockStandardAssembly;
+ }
}
}
diff --git a/src/Tests/Tests.IQsharp.csproj b/src/Tests/Tests.IQsharp.csproj
index d575590fa5..059313ded9 100644
--- a/src/Tests/Tests.IQsharp.csproj
+++ b/src/Tests/Tests.IQsharp.csproj
@@ -28,7 +28,8 @@
-
+
+
@@ -49,6 +50,18 @@
PreserveNewest
+
+ PreserveNewest
+
+
+ PreserveNewest
+
+
+ PreserveNewest
+
+
+ PreserveNewest
+
diff --git a/src/Tests/Workspace.ExecutionPathTracer/Canon.qs b/src/Tests/Workspace.ExecutionPathTracer/Canon.qs
new file mode 100644
index 0000000000..658b765ba4
--- /dev/null
+++ b/src/Tests/Workspace.ExecutionPathTracer/Canon.qs
@@ -0,0 +1,18 @@
+// Copyright (c) Microsoft Corporation. All rights reserved.
+// Licensed under the MIT License.
+
+namespace Tests.ExecutionPathTracer {
+
+ open Microsoft.Quantum.Intrinsic;
+ open Mock.Standard;
+
+ operation ApplyToEachCirc() : Unit {
+ using (qs = Qubit[3]) {
+ ApplyToEach(H, qs);
+ ResetAll(qs);
+ }
+ }
+
+}
+
+
diff --git a/src/Tests/Workspace.ExecutionPathTracer/Circuits.qs b/src/Tests/Workspace.ExecutionPathTracer/Circuits.qs
new file mode 100644
index 0000000000..40c01b8675
--- /dev/null
+++ b/src/Tests/Workspace.ExecutionPathTracer/Circuits.qs
@@ -0,0 +1,98 @@
+// Copyright (c) Microsoft Corporation. All rights reserved.
+// Licensed under the MIT License.
+
+namespace Tests.ExecutionPathTracer {
+
+ open Microsoft.Quantum.Intrinsic;
+
+ // Custom operation
+ operation Foo(theta : Double, (qubit : Qubit, bar : String)) : Unit
+ is Adj + Ctl {
+ }
+
+ operation FooCirc() : Unit {
+ using (q = Qubit()) {
+ Foo(2.1, (q, "bar"));
+ }
+ }
+
+ operation ControlledFooCirc() : Unit {
+ using (qs = Qubit[2]) {
+ Controlled Foo([qs[0]], (2.1, (qs[1], "bar")));
+ }
+ }
+
+ operation UnusedQubitCirc() : Unit {
+ using (qs = Qubit[3]) {
+ CNOT(qs[2], qs[0]);
+ Reset(qs[0]);
+ Reset(qs[2]);
+ }
+ }
+
+ operation EmptyCirc() : Unit {
+ using (qs = Qubit[3]) {
+ }
+ }
+
+ operation NoQubitCirc(n : Int) : Unit {
+ }
+
+ operation NoQubitArgsCirc() : Unit {
+ NoQubitCirc(2);
+ }
+
+ operation OperationCirc(op : (Qubit => Unit), n : Int) : Unit {
+ }
+
+ operation OperationArgsCirc() : Unit {
+ OperationCirc(H, 5);
+ }
+
+ operation NestedCirc() : Unit {
+ using (q = Qubit()) {
+ H(q);
+ HCirc();
+ Reset(q);
+ }
+ }
+
+ operation FooBar(q : Qubit) : Unit {
+ H(q);
+ X(q);
+ }
+
+ operation Depth2Circ() : Unit {
+ using (q = Qubit()) {
+ FooBar(q);
+ H(q);
+ }
+ }
+
+ operation PartialOpCirc() : Unit {
+ using (qs = Qubit[3]) {
+ (Controlled H(qs[0..1], _))(qs[2]);
+ ((Ry(_, _))(2.5, _))(qs[0]);
+ ResetAll(qs);
+ }
+ }
+
+ operation Bar((alpha : Double, beta : Double), (q : Qubit, name : String)) : Unit
+ is Adj + Ctl {
+ }
+
+ operation BigCirc() : Unit {
+ using (qs = Qubit[3]) {
+ H(qs[0]);
+ Ry(2.5, qs[1]);
+ Bar((1.0, 2.1), (qs[0], "foo"));
+ X(qs[0]);
+ CCNOT(qs[0], qs[1], qs[2]);
+ Controlled CNOT([qs[0]], (qs[1], qs[2]));
+ Controlled Adjoint Bar([qs[2]], ((1.0, 2.1), (qs[0], "foo")));
+ let res = M(qs[0]);
+ ResetAll(qs);
+ }
+ }
+
+}
diff --git a/src/Tests/Workspace.ExecutionPathTracer/Intrinsic.qs b/src/Tests/Workspace.ExecutionPathTracer/Intrinsic.qs
new file mode 100644
index 0000000000..ffb7b91295
--- /dev/null
+++ b/src/Tests/Workspace.ExecutionPathTracer/Intrinsic.qs
@@ -0,0 +1,68 @@
+// Copyright (c) Microsoft Corporation. All rights reserved.
+// Licensed under the MIT License.
+
+namespace Tests.ExecutionPathTracer {
+
+ open Microsoft.Quantum.Intrinsic;
+
+ operation HCirc() : Unit {
+ using (q = Qubit()) {
+ H(q);
+ Reset(q);
+ }
+ }
+
+ operation MCirc() : Unit {
+ using (q = Qubit()) {
+ let res = M(q);
+ }
+ }
+
+ operation CnotCirc() : Unit {
+ using (qs = Qubit[2]) {
+ CNOT(qs[0], qs[1]);
+ ResetAll(qs);
+ }
+ }
+
+ operation CcnotCirc() : Unit {
+ using (qs = Qubit[3]) {
+ CCNOT(qs[0], qs[2], qs[1]);
+ ResetAll(qs);
+ }
+ }
+
+ operation SwapCirc() : Unit {
+ using (qs = Qubit[2]) {
+ SWAP(qs[0], qs[1]);
+ }
+ }
+
+ operation RxCirc() : Unit {
+ using (q = Qubit()) {
+ Rx(2.0, q);
+ Reset(q);
+ }
+ }
+
+ operation AdjointHCirc() : Unit {
+ using (q = Qubit()) {
+ Adjoint H(q);
+ Reset(q);
+ }
+ }
+
+ operation ControlledXCirc() : Unit {
+ using (qs = Qubit[2]) {
+ Controlled X([qs[0]], qs[1]);
+ ResetAll(qs);
+ }
+ }
+
+ operation ControlledAdjointSCirc() : Unit {
+ using (qs = Qubit[2]) {
+ Controlled Adjoint S([qs[0]], qs[1]);
+ ResetAll(qs);
+ }
+ }
+}
diff --git a/src/Tests/Workspace.ExecutionPathTracer/Measurement.qs b/src/Tests/Workspace.ExecutionPathTracer/Measurement.qs
new file mode 100644
index 0000000000..1b78f87ff3
--- /dev/null
+++ b/src/Tests/Workspace.ExecutionPathTracer/Measurement.qs
@@ -0,0 +1,36 @@
+// Copyright (c) Microsoft Corporation. All rights reserved.
+// Licensed under the MIT License.
+
+namespace Tests.ExecutionPathTracer {
+
+ open Microsoft.Quantum.Measurement;
+ open Microsoft.Quantum.Arrays;
+ open Mock.Standard;
+
+ operation MResetXCirc() : Unit {
+ using (q = Qubit()) {
+ let res = MResetX(q);
+ }
+ }
+
+ operation MResetYCirc() : Unit {
+ using (q = Qubit()) {
+ let res = MResetY(q);
+ }
+ }
+
+ operation MResetZCirc() : Unit {
+ using (q = Qubit()) {
+ let res = MResetZ(q);
+ }
+ }
+
+ operation ForEachMeasureCirc() : Unit {
+ using (qs = Qubit[2]) {
+ let res = ForEach(MResetZ, qs);
+ }
+ }
+
+}
+
+
diff --git a/src/Tool/appsettings.json b/src/Tool/appsettings.json
index 5b42ab8d04..7ec58902e5 100644
--- a/src/Tool/appsettings.json
+++ b/src/Tool/appsettings.json
@@ -6,25 +6,25 @@
},
"AllowedHosts": "*",
"DefaultPackageVersions": [
- "Microsoft.Quantum.Compiler::0.12.20072031",
+ "Microsoft.Quantum.Compiler::0.12.20073008-beta",
- "Microsoft.Quantum.CsharpGeneration::0.12.20072031",
- "Microsoft.Quantum.Development.Kit::0.12.20072031",
- "Microsoft.Quantum.Simulators::0.12.20072031",
- "Microsoft.Quantum.Xunit::0.12.20072031",
+ "Microsoft.Quantum.CsharpGeneration::0.12.20073008-beta",
+ "Microsoft.Quantum.Development.Kit::0.12.20073008-beta",
+ "Microsoft.Quantum.Simulators::0.12.20073008-beta",
+ "Microsoft.Quantum.Xunit::0.12.20073008-beta",
- "Microsoft.Quantum.Standard::0.12.20072031",
- "Microsoft.Quantum.Chemistry::0.12.20072031",
- "Microsoft.Quantum.Chemistry.Jupyter::0.12.20072031",
- "Microsoft.Quantum.MachineLearning::0.12.20072031",
- "Microsoft.Quantum.Numerics::0.12.20072031",
+ "Microsoft.Quantum.Standard::0.12.20073008-beta",
+ "Microsoft.Quantum.Chemistry::0.12.20073008-beta",
+ "Microsoft.Quantum.Chemistry.Jupyter::0.12.20073008-beta",
+ "Microsoft.Quantum.MachineLearning::0.12.20073008-beta",
+ "Microsoft.Quantum.Numerics::0.12.20073008-beta",
- "Microsoft.Quantum.Katas::0.12.20072031",
+ "Microsoft.Quantum.Katas::0.12.20073008-beta",
- "Microsoft.Quantum.Research::0.12.20072031",
+ "Microsoft.Quantum.Research::0.12.20073008-beta",
- "Microsoft.Quantum.Providers.IonQ::0.12.20072031",
- "Microsoft.Quantum.Providers.Honeywell::0.12.20072031",
- "Microsoft.Quantum.Providers.QCI::0.12.20072031"
+ "Microsoft.Quantum.Providers.IonQ::0.12.20073008-beta",
+ "Microsoft.Quantum.Providers.Honeywell::0.12.20073008-beta",
+ "Microsoft.Quantum.Providers.QCI::0.12.20073008-beta"
]
}