IOleParentUndoUnit::Close 方法 (ocidl.h)
关闭指定的父撤消单元。
语法
HRESULT Close(
[in] IOleParentUndoUnit *pPUU,
[in] BOOL fCommit
);
参数
[in] pPUU
指向当前打开的要关闭的父单元的 IOleParentUndoUnit 指针。
[in] fCommit
指示是保留还是放弃单位。 如果 为 TRUE,则单位保留在集合中。 如果 为 FALSE,则放弃该单位。 此参数用于允许客户端在发生错误或取消时放弃正在构造的撤消单位。
返回值
此方法在成功时返回S_OK。 其他可能的返回值包括以下内容。
返回代码 | 说明 |
---|---|
|
父撤消单元没有打开的子级,并且已成功关闭。 |
|
如果 pPUU 与当前打开的父撤消单元不匹配,则此方法的实现应返回E_INVALIDARG,而不会更改任何内部状态,除非阻止父单元。 |
注解
父撤消单元在从此方法返回S_FALSE时知道它正在关闭。 此时,它应终止与可能通过专用接口向其提供数据的其他对象的任何通信。
给调用方的说明
错误返回指示严重错误条件。如果 fCommit 为 TRUE,则父单元或撤消管理器必须接受撤消单元。
实施者说明
若要处理关闭请求,父撤消单元首先检查它是否具有打开的子单元。 如果未返回,则返回S_FALSE。如果确实打开了子单元,则调用子单元上的 IOleParentUndoUnit::Close 方法。 如果子级返回S_FALSE,则父撤消单元会验证 pPUU 指向子单元,并关闭该子撤消单元。 如果子级返回S_OK则它在内部处理关闭,其父级不应执行任何操作。
如果父单元被阻止,它应检查 pPUU 参数来确定适当的返回代码。 如果 pPUU 指向自身,则它应返回S_FALSE。
否则,它应返回S_OK; 忽略 fCommit 参数;且不执行任何操作。
如果 pPUU 与当前打开的父撤消单元不匹配,则此方法的实现应返回E_INVALIDARG,而不会更改任何内部状态。 唯一的例外是单位被阻止。
要求
要求 | 值 |
---|---|
最低受支持的客户端 | Windows 2000 Professional [仅限桌面应用] |
最低受支持的服务器 | Windows 2000 Server [仅限桌面应用] |
目标平台 | Windows |
标头 | ocidl.h |