Epizód
Töredezettségmentesítési eszközök #170 – Hibakereső – JavaScript-szkriptelés
Ebben az epizódban a Defrag Tools, Andrew Richards beszél Andy Luhrs és Bill Messmer a Hibakeresési eszközök a Windows csapat. A WDK és az SDK 14951-es és újabb buildjében elérhető Új JavaScript bővíthetőségről és szkriptelési képességekről beszélünk a WinDbg-ben.
- Blog- https://blogs.msdn.microsoft.com/windbg/
- E-mail- windbgfb@microsoft.com
Bill a hibakereső objektummodellt használja az alábbi epizódokban korábban:
- Töredezettségmentesítési eszközök #138 – Hibakeresés – "dx" parancs 1. rész
- Töredezettségmentesítési eszközök #139 – Hibakeresés – "dx" parancs 2. rész
- Töredezettségmentesítési eszközök #169 – Hibakeresési eszközök Windows-csapathoz
Idővonal:
[00:00] Köszöntés és bevezetés
[00:24] Új SDK-csökkenés
[00:29] Miért javaScript
[02:07] Új parancsok
[03:50] Visual Studio Code
[04:00] Példa – "Helló világ!" alkalmazás
[07:15] Hibakereső alapértelmezett névterei
[09:07] Példa – Az összes szál nyomtatása
[10:26] Példa – Feltételes töréspont
[18:13] "g" vs. "gc" – Andrew-nak igaza volt! A "gc" ugyanúgy folytatja a végrehajtást, mint ahogy elindult. Tehát ha a "p"-t, majd egy feltételes töréspontot talál, amelyben a "gc" szerepel, a "gc" csak befejezi a kezdeti "p"-t.
[20:40] Példa – Egyedi verem
[34:40] Példa – Hozzáadás
Kérdések/megjegyzések? E-mail címünk: defragtools@microsoft.com
JavaScript MSDN-dokumentumok:
- JavaScript-hibakereső szkriptelése
- JavaScript-hibakereső példaszkriptjei
- Natív hibakereső objektumok JavaScript-bővítményekben
Egyedi verem példa (a megfelelő):
"szigorú használat";
class __stackEntry { constructor(frameString) { this.threads = []; this.frameString = frameString; this.children = new Map(); }
display(indent)
{
for (var child of this.children.values())
{
host.diagnostics.debugLog(indent, child.frameString, " [Threads In Branch: ");
for (var thread of child.threads)
{
host.diagnostics.debugLog(thread.Id, " ");
}
host.diagnostics.debugLog("]\n");
child.display(indent + " ");
}
}
}
osztály __stackMap { konstruktor(folyamat) { this.__process = folyamat; this.__root = új __stackEntry(""); this.build(); }
build()
{
for (var thread of this.__process.Threads)
{
var current = this.__root;
var frameNum = 0;
var frameCount = thread.Stack.Frames.Count();
for (var frameNum = frameCount - 1; frameNum >= 0; --frameNum) {
var frame = thread.Stack.Frames[frameNum];
var frameString = frame.toString();
if (current.children.has(frameString)) {
current = current.children.get(frameString);
current.threads.push(thread);
}
else {
var newEntry = new __stackEntry(frameString);
current.children.set(frameString, newEntry);
current = newEntry;
current.threads.push(thread);
}
}
}
}
findEntry(thread)
{
var current = this.__root;
var frameCount = thread.Stack.Frames.Count();
for (var frameNum = frameCount - 1; frameNum >= 0; --frameNum)
{
var frame = thread.Stack.Frames[frameNum];
var frameString = frame.toString();
if (!current.children.has(frameString))
{
return null;
}
current = current.children.get(frameString);
}
return current;
}
display()
{
this.__root.display("");
}
}
osztály __threadSameStacks { konstruktor(szál) { this.__thread = szál; }
getDimensionality()
{
return 1;
}
getValueAt(idx)
{
for (var idxVal of this)
{
var tid = idxVal[Symbol.indicies][0];
if (idxVal[Symbol.indicies][0] == idx && tid != this.__thread.Id)
{
return idxVal.value;
}
}
return undefined;
}
*[Symbol.iterator]()
{
var context = this.__thread.hostContext;
var session = host.namespace.Debugger.Sessions.getValueAt(context);
var process = session.Processes.getValueAt(context);
var map = new __stackMap(process);
var entry = map.findEntry(this.__thread);
if (entry != null)
{
for (var sharingThread of entry.threads)
{
if (sharingThread.Id != this.__thread.Id)
{
yield new host.indexedValue(sharingThread, [sharingThread.Id]);
}
}
}
}
}
class __threadExtension { get IdenticalStacks() { return new __threadSameStacks(this); } }
function invokeScript() { var map = new __stackMap(host.currentProcess); map.display(); }
function initializeScript() { return [new host.namedModelParent(__threadExtension, "Debugger.Models.Thread")]; }
Ebben az epizódban a Defrag Tools, Andrew Richards beszél Andy Luhrs és Bill Messmer a Hibakeresési eszközök a Windows csapat. A WDK és az SDK 14951-es és újabb buildjében elérhető Új JavaScript bővíthetőségről és szkriptelési képességekről beszélünk a WinDbg-ben.
- Blog- https://blogs.msdn.microsoft.com/windbg/
- E-mail- windbgfb@microsoft.com
Bill a hibakereső objektummodellt használja az alábbi epizódokban korábban:
- Töredezettségmentesítési eszközök #138 – Hibakeresés – "dx" parancs 1. rész
- Töredezettségmentesítési eszközök #139 – Hibakeresés – "dx" parancs 2. rész
- Töredezettségmentesítési eszközök #169 – Hibakeresési eszközök Windows-csapathoz
Idővonal:
[00:00] Köszöntés és bevezetés
[00:24] Új SDK-csökkenés
[00:29] Miért javaScript
[02:07] Új parancsok
[03:50] Visual Studio Code
[04:00] Példa – "Helló világ!" alkalmazás
[07:15] Hibakereső alapértelmezett névterei
[09:07] Példa – Az összes szál nyomtatása
[10:26] Példa – Feltételes töréspont
[18:13] "g" vs. "gc" – Andrew-nak igaza volt! A "gc" ugyanúgy folytatja a végrehajtást, mint ahogy elindult. Tehát ha a "p"-t, majd egy feltételes töréspontot talál, amelyben a "gc" szerepel, a "gc" csak befejezi a kezdeti "p"-t.
[20:40] Példa – Egyedi verem
[34:40] Példa – Hozzáadás
Kérdések/megjegyzések? E-mail címünk: defragtools@microsoft.com
JavaScript MSDN-dokumentumok:
- JavaScript-hibakereső szkriptelése
- JavaScript-hibakereső példaszkriptjei
- Natív hibakereső objektumok JavaScript-bővítményekben
Egyedi verem példa (a megfelelő):
"szigorú használat";
class __stackEntry { constructor(frameString) { this.threads = []; this.frameString = frameString; this.children = new Map(); }
display(indent)
{
for (var child of this.children.values())
{
host.diagnostics.debugLog(indent, child.frameString, " [Threads In Branch: ");
for (var thread of child.threads)
{
host.diagnostics.debugLog(thread.Id, " ");
}
host.diagnostics.debugLog("]\n");
child.display(indent + " ");
}
}
}
osztály __stackMap { konstruktor(folyamat) { this.__process = folyamat; this.__root = új __stackEntry(""); this.build(); }
build()
{
for (var thread of this.__process.Threads)
{
var current = this.__root;
var frameNum = 0;
var frameCount = thread.Stack.Frames.Count();
for (var frameNum = frameCount - 1; frameNum >= 0; --frameNum) {
var frame = thread.Stack.Frames[frameNum];
var frameString = frame.toString();
if (current.children.has(frameString)) {
current = current.children.get(frameString);
current.threads.push(thread);
}
else {
var newEntry = new __stackEntry(frameString);
current.children.set(frameString, newEntry);
current = newEntry;
current.threads.push(thread);
}
}
}
}
findEntry(thread)
{
var current = this.__root;
var frameCount = thread.Stack.Frames.Count();
for (var frameNum = frameCount - 1; frameNum >= 0; --frameNum)
{
var frame = thread.Stack.Frames[frameNum];
var frameString = frame.toString();
if (!current.children.has(frameString))
{
return null;
}
current = current.children.get(frameString);
}
return current;
}
display()
{
this.__root.display("");
}
}
osztály __threadSameStacks { konstruktor(szál) { this.__thread = szál; }
getDimensionality()
{
return 1;
}
getValueAt(idx)
{
for (var idxVal of this)
{
var tid = idxVal[Symbol.indicies][0];
if (idxVal[Symbol.indicies][0] == idx && tid != this.__thread.Id)
{
return idxVal.value;
}
}
return undefined;
}
*[Symbol.iterator]()
{
var context = this.__thread.hostContext;
var session = host.namespace.Debugger.Sessions.getValueAt(context);
var process = session.Processes.getValueAt(context);
var map = new __stackMap(process);
var entry = map.findEntry(this.__thread);
if (entry != null)
{
for (var sharingThread of entry.threads)
{
if (sharingThread.Id != this.__thread.Id)
{
yield new host.indexedValue(sharingThread, [sharingThread.Id]);
}
}
}
}
}
class __threadExtension { get IdenticalStacks() { return new __threadSameStacks(this); } }
function invokeScript() { var map = new __stackMap(host.currentProcess); map.display(); }
function initializeScript() { return [new host.namedModelParent(__threadExtension, "Debugger.Models.Thread")]; }