IDataModelScriptDebug2::GetCurrentPosition 方法 (dbgmodel.h)

GetCurrentPosition 的 方法返回脚本中的当前位置。 仅当脚本被分解为调试器,其中调用 GetScriptState 将返回 ScriptDebugBreak 时,才能调用此脚本。 对此方法的任何其他调用都无效,并且将失败。

脚本的位置定义为字符范围。 必须始终 (行号和列号) 返回范围的开头。 如果特定调试器能够返回脚本中“当前位置”的完整范围,则可以选择在 positionSpanEnd 参数中返回结束位置。 如果调试器无法执行此操作,则范围末尾的行和列值 (如果请求) 应设置为零。

如果调试器可以传递调试器损坏的代码行的源代码,则它可能会从此方法返回此类代码。 如果可能,强烈建议提供此信息。 但是,不要求返回比中断位置的起始行和列更多的信息。 如果不支持源行信息,可能会为该参数返回 nullptr 值。

语法

HRESULT GetCurrentPosition(
  ScriptDebugPosition *currentPosition,
  ScriptDebugPosition *positionSpanEnd,
  BSTR                *lineText
);

参数

currentPosition

必须在此处返回脚本的当前中断位置。 返回结构的“行”和“列”字段基于 1。 中的零值表示信息不可用。

positionSpanEnd

如果调试器能够确定中断位置的完整范围,则可以在此处返回范围的结束位置。 否则,应将零个值填充到返回结构的“行”和“列”字段中。

lineText

如果调试器能够返回行 (或中断范围) 的源代码,则可以在此处作为 SysAllocString 函数分配的字符串返回。 调用方负责使用 SysFreeString 释放返回的字符串。 如果调试器无法生成此源信息,则应返回 nullptr。

返回值

此方法返回指示成功或失败的 HRESULT。

要求

要求
Header dbgmodel.h

另请参阅

IDataModelScriptDebug2 接口