Метод IDebugAdvanced3::FindSourceFileAndTokenWide (dbgeng.h)
Метод FindSourceFileAndTokenWide возвращает имя исходного файла по исходному пути или значение переменной, связанной с маркером файла.
Синтаксис
HRESULT FindSourceFileAndTokenWide(
[in] ULONG StartElement,
[in] ULONG64 ModAddr,
[in] PCWSTR File,
[in] ULONG Flags,
[in, optional] PVOID FileToken,
[in] ULONG FileTokenSize,
[out, optional] PULONG FoundElement,
[out, optional] PWSTR Buffer,
[in] ULONG BufferSize,
[out, optional] PULONG FoundSize
);
Параметры
[in] StartElement
Указывает индекс элемента в исходном пути для начала поиска. Все элементы в исходном пути до StartElement исключаются из поиска. Индекс первого элемента равен нулю. Если startElement больше или равно количеству элементов в исходном пути, система подачи проверяется напрямую.
Этот параметр можно использовать с FoundElement для проверка для нескольких совпадений в исходном пути.
Параметр StartElement игнорируется, если флаг DEBUG_FIND_SOURCE_TOKEN_LOOKUP установлен в разделе Флаги.
[in] ModAddr
Указывает расположение в выделении памяти модуля в целевом объекте, с которым связан исходный файл. ModAddr используется для кэширования результатов поиска и при запросе исходных серверов для файла. ModAddr может иметь значение NULL.
Параметр ModAddr игнорируется, если флаг DEBUG_FIND_SOURCE_TOKEN_LOOKUP установлен в разделе Флаги. Кроме того, он не используется для запросов к исходным серверам, если FileToken не имеет значение NULL.
[in] File
Указывает путь и имя файла для поиска.
Если флаг DEBUG_FIND_SOURCE_TOKEN_LOOKUP установлен, файл уже указан маркером в FileToken. В этом случае Файл указывает имя переменной на исходном сервере, связанной с файлом. Переменная должна начинаться и заканчиваться знаком процента ( % ), например % SRCSRVCMD%. Возвращается значение этой переменной.
[in] Flags
Задает флаги, управляющие поведением этого метода. Описание этих флагов см. в разделе DEBUG_FIND_SOURCE_XXX.
[in, optional] FileToken
Указывает маркер файла, представляющий файл на исходном сервере. Маркер файла можно получить, задав параметр DEBUG_SRCFILE_SYMBOL_TOKEN в методе GetSourceFileInformation.
Если флаг DEBUG_FIND_SOURCE_TOKEN_LOOKUP установлен, FileToken не должен иметь значение NULL.
[in] FileTokenSize
Указывает размер маркера FileToken в байтах. Если FileToken имеет значение NULL, этот параметр игнорируется.
[out, optional] FoundElement
Получает индекс элемента в исходном пути, содержавшемся в файле. Если файл найден непосредственно в системе подачи (не используя исходный путь), значение -1 возвращается в FoundElement. Если свойство FoundElement имеет значение NULL или флаги содержат DEBUG_SRCFILE_SYMBOL_TOKEN, эти сведения не возвращаются.
[out, optional] Buffer
Получает имя найденного файла. Если файл не находится на исходном сервере, это имя файла в локальном исходном кэше. Если флаг DEBUG_FIND_SOURCE_FULL_PATH установлен, это полное каноническое имя пути к файлу. В противном случае для поиска файла используется объединение каталога в исходном пути с конечным фрагментом Файла .
Если флаг DEBUG_SRCFILE_SYMBOL_TOKEN задан в разделе Флаги, буфер получает значение переменной File , связанной с маркером файла FileToken.
Если параметр Buffer имеет значение NULL, эта информация не возвращается.
[in] BufferSize
Задает размер буфера буфера буфера в символах. Этот размер включает пробел для символа завершения "\0". Если параметр Buffer имеет значение NULL, этот параметр игнорируется.
[out, optional] FoundSize
Задает размер имени файла в символах. Этот размер включает пробел для символа завершения "\0". Если параметр foundSize имеет значение NULL, эта информация не возвращается.
Возвращаемое значение
Этот метод также может возвращать значения ошибок. Дополнительные сведения см. в разделе Возвращаемые значения .
Код возврата | Описание |
---|---|
|
Метод выполнен успешно. |
|
Метод выполнен успешно. Однако буфер буфера был слишком мал для хранения имени файла или значения переменной, поэтому строка была усечена для размещения в буфере. |
Комментарии
Если DEBUG_SRCFILE_SYMBOL_TOKEN флага задано в разделе Флаги, этот метод не выполняет поиск файла по исходному пути. Вместо этого он ищет переменную, связанную с маркером файла, предоставленным в FileToken. Эти переменные описаны в разделе Языковая спецификация 1. Например, чтобы получить значение переменной SRCSRVCMD — команда для извлечения исходного файла из системы управления версиями (также возвращенная функцией DEBUG_SRCFILE_SYMBOL_TOKEN_SOURCE_COMMAND_WIDE GetSourceFileInformation) — задайте для параметра Fileзначение %SRCSRVCMD%.
Для поиска файла подсистема выполняет следующие действия по порядку:
-
Если исходный путь содержит все исходные серверы и флаг DEBUG_FIND_SOURCE_NO_SRCSRV не установлен, сначала выполняется поиск исходного сервера в исходном пути.
Возвращается первое найденное совпадение.
-
Для каждого каталога в исходном пути выполняется попытка найти перекрытие между концом пути к каталогу и началом пути к файлу. Например, если исходный путь содержит каталог C:\a\b\c\d, а файл — c\d\e\foo.c, то файл C:\a\b\c\d\e\foo.c является совпадением.
Если установлен флаг DEBUG_FIND_SOURCE_BEST_MATCH, возвращается совпадение с самым длинным перекрытием; В противном случае возвращается первое совпадение.
-
Для каждого каталога в исходном пути к каталогу добавляется файл . Если совпадение не найдено, этот процесс повторяется и каждый раз при удалении первого каталога из начала пути к файлу. Например, если исходный путь содержит каталог C:\a\b, а файл — c\d\e\foo.c, то файл C:\a\b\e\foo.c является совпадением.
Возвращается первое найденное совпадение.
- Файл ищется непосредственно в системе подачи.
Требования
Требование | Значение |
---|---|
Целевая платформа | Персональный компьютер |
Верхняя часть | dbgeng.h (включая Dbgeng.h) |