Метод IDebugSymbols::FindSourceFile (dbgeng.h)
Метод FindSourceFile выполняет поиск указанного исходного файла по исходному пути.
Синтаксис
HRESULT FindSourceFile(
[in] ULONG StartElement,
[in] PCSTR File,
[in] ULONG Flags,
[out, optional] PULONG FoundElement,
[out, optional] PSTR Buffer,
[in] ULONG BufferSize,
[out, optional] PULONG FoundSize
);
Параметры
[in] StartElement
Указывает индекс элемента в исходном пути для начала поиска. Все элементы в исходном пути до StartElement исключаются из поиска. Индекс первого элемента равен нулю. Если значение StartElement больше или равно количеству элементов в исходном пути, система подачи проверяется напрямую.
Этот параметр можно использовать с FoundElement для проверка для нескольких совпадений в исходном пути.
[in] File
Указывает путь и имя файла для поиска.
[in] Flags
Указывает флаги поиска. Описание этих флагов см. в разделе DEBUG_FIND_SOURCE_XXX.
Не следует задавать DEBUG_FIND_SOURCE_TOKEN_LOOKUP флага. Флаг DEBUG_FIND_SOURCE_NO_SRCSRV игнорируется, так как этот метод не включает исходные серверы в поиск.
[out, optional] FoundElement
Получает индекс элемента в исходном пути, который содержит файл. Если файл был найден непосредственно в системе подачи данных (не используя исходный путь), значение -1 возвращается в FoundElement. Если свойство FoundElement имеет значение NULL, эти сведения не возвращаются.
[out, optional] Buffer
Получает путь и имя найденного файла. Если флаг DEBUG_FIND_SOURCE_FULL_PATH установлен, это полное каноническое имя пути к файлу. В противном случае это объединение каталога в исходном пути с заключительным фрагментом файла, который использовался для поиска файла. Если параметр Buffer имеет значение NULL, эти сведения не возвращаются.
[in] BufferSize
Указывает размер буфера в символах.
[out, optional] FoundSize
Указывает размер (в символах) имени файла. Если параметр FoundSize имеет значение NULL, эти сведения не возвращаются.
Возвращаемое значение
Этот метод также может возвращать значения ошибок. Дополнительные сведения см. в разделе Возвращаемые значения .
Код возврата | Описание |
---|---|
|
Метод выполнен успешно. |
|
Файл не найден в исходном пути. |
Комментарии
Для поиска файла подсистема выполняет следующие действия (по порядку).
-
Для каждого каталога в исходном пути предпринимается попытка найти перекрытие между концом пути к каталогу и началом пути к файлу. Например, если исходный путь содержит каталог C:\a\b\c\d, а файл — c\d\e\samplefile.c, то файл C:\a\b\c\d\e\samplefile.c является совпадением.
Если установлен флаг DEBUG_FIND_SOURCE_BEST_MATCH, возвращается совпадение с самым длинным перекрытием; В противном случае возвращается первое совпадение.
-
Для каждого каталога в исходном пути к каталогу добавляется файл . Если совпадения не найдены, этот процесс повторяется и каждый раз при удалении первого каталога из начала пути к файлу. Например, если исходный путь содержит каталог C:\a\b, а файл — c\d\e\samplefile.c, то файл C:\a\b\e\samplefile.c является совпадением.
Возвращается первое найденное совпадение.
- Поиск файла выполняется непосредственно в системе подачи.
Требования
Требование | Значение |
---|---|
Целевая платформа | Персональный компьютер |
Верхняя часть | dbgeng.h (включая Dbgeng.h) |