我正在为Qt类创建一个natvis文件,我遇到了一个问题。
为了可视化QHash对象,我创建了这两种类型:
<Type Name="QHashNode<*,*>">
<DisplayString Condition="next->next == 0">{{ key={key} value={value} h={h}}}</DisplayString>
<DisplayString>{{ key={key} value={value} h={h} withCollision }}</DisplayString>
<Expand>
<Item Name="NextNode">reinterpret_cast<QHashNode<$T1,$T2> *>(next)</Item>
</Expand>
</Type>
<Type Name="QHash<*,*>">
<DisplayString>{{ size={d->size} buckets={d->numBuckets} }}</DisplayString>
<Expand>
<IndexListItems>
<Size>d->numBuckets</Size>
<ValueNode Condition="reinterpret_cast<QHashNode<$T1,$T2> *>(d->buckets[$i]) != e">reinterpret_cast<QHashNode<$T1,$T2> *>(d->buckets[$i])</ValueNode>
</IndexListItems>
</Expand>
</Type>它基本上是有效的,但由于QHash在内存中不连续,因此有很多无效条目。条件
reinterpret_cast<QHashNode<
$T1,$T2> *>(d->buckets[$i]) != e 已经过滤掉了那些无效的,但它们仍然显示为<Unable to display value>。
有没有人知道是否有办法完全跳过这些条目?
我从来没有真正使用过autoexp.dat文件,这是一种旧的方法,但当我查看安装了Qt插件的文件时,在我看来,语句
#switch ($e.next != 0) #case 1 (
$e
)确实如此,所以我希望在natvis文件中也可以这样做?
如果有人感兴趣,我可以给你natvis文件,但到目前为止,我只有QString,QByteArray,QList,QVector,QMap和(有问题的) QHash。
发布于 2013-09-24 11:25:00
根据MSDN page on writing type visualizers的定义,<IndexListItems>是连续的:
IndexListItems Expansion
ArrayItems假设数组元素在内存中连续布局。调试器通过简单地递增指向当前元素的指针来到达下一个元素。为了支持需要操作值节点的索引的情况,可以使用索引列表项。这是一个使用'IndexListItems‘节点的可视化工具:....ArrayItems和IndexListItems之间的唯一区别是,“ValueNode”需要具有隐式“$i”参数的第i个元素的完整表达式。
另外,我可以告诉你the Qt Labs VSTools repository和its documentation吗?特别是,tools/Qt4EEAddin/qt5.natvis看起来非常像我认为您正在尝试编写的内容?(或者它实际上是您正在编写的内容吗?^_^)无论哪种方式,我认为您能做的最好的事情就是在qt5.natvis中做什么,它有一个特殊的<DisplayString>来表示空的QHashNodes,但不会试图省略QHash中的空buckets。
发布于 2013-09-19 14:15:15
https://stackoverflow.com/questions/13748209
复制相似问题