Метод ITextStoreACP2::RequestLock (texttor.h)
Вызывается менеджером TSF для обеспечения блокировки документа для изменения документа. Этот метод вызывает метод OnLockGranted для создания блокировки документа.
Синтаксис
HRESULT RequestLock(
[in] DWORD dwLockFlags,
[out] HRESULT *phrSession
);
Параметры
[in] dwLockFlags
Указывает тип запрошенной блокировки.
[out] phrSession
Если запрос на блокировку является синхронным, получает значение HRESULT от метода OnLockGranted , указывающее результат запроса на блокировку.
Если запрос на блокировку является асинхронным и результатом является TS_S_ASYNC, документ получает асинхронную блокировку. Если запрос на блокировку является асинхронным и результатом является TS_E_SYNCHRONOUS, документ нельзя заблокировать синхронно.
Возвращаемое значение
Этот метод может возвращать одно из этих значений.
Значение | Описание |
---|---|
|
Метод выполнен успешно. |
|
Произошла неизвестная ошибка. |
Комментарии
Этот метод использует метод OnLockGranted для блокировки документа. Приложения никогда не должны изменять документ или отправлять уведомления об изменениях с помощью метода OnTextChange из метода RequestLock . Если приложение содержит ожидающие изменения в отчете, оно может отвечать только на запрос асинхронной блокировки.
Приложения не должны пытаться ставить в очередь несколько вызовов метода RequestLock , так как приложению требуется только один обратный вызов. Однако если вызывающий объект выполняет несколько запросов на чтение и один или несколько запросов на запись, обратный вызов должен быть для доступа на запись.
Успешные запросы синхронных блокировок заменяют запросы на асинхронные блокировки. Неудачные запросы на синхронные блокировки не заменяют запросы на асинхронные блокировки. Реализация по-прежнему должна обслуживать невыполненные асинхронные запросы, если он существует.
Если блокировка предоставляется до возврата метода RequestLock , параметр phrSession получит hrESULT, возвращенный методом OnLockGranted . Если вызов выполнен успешно, но блокировка будет предоставлена позже, параметр phrSession получает флаг TS_S_ASYNC. Параметр phrSession следует игнорировать, если RequestLock возвращает не S_OK.
Вызывающий объект никогда не должен повторно вызывать этот метод, за исключением случаев, когда вызывающий объект удерживает блокировку только для чтения. В этом случае метод можно вызвать повторно, чтобы запросить асинхронную блокировку записи. Блокировка записи будет предоставлена позже, после завершения блокировки только для чтения.
Дополнительные сведения о блокировках документов см. в разделе Блокировки документов.
Требования
Требование | Значение |
---|---|
Минимальная версия клиента | Windows 8 [классические приложения | Приложения UWP] |
Минимальная версия сервера | Windows Server 2012 [классические приложения | Приложения UWP] |
Целевая платформа | Windows |
Header | textstor.h |
DLL | Msctf.dll |