#import 生成不正确的 TLH 文件
Posted
技术标签:
【中文标题】#import 生成不正确的 TLH 文件【英文标题】:#import generates incorrect TLH file 【发布时间】:2017-01-30 04:53:09 【问题描述】:我正在尝试创建一个包含项目中所有#imports 的stdafx.cpp 文件以缩短构建时间。我想包括 Office 2010、2013 和 2016 的 word/excel/ppt 的所有导入。
当我将所有导入放在 CPP 中时,没有问题,但是当我将所有#imports 放在 stdafx.cpp 中时。 cx_excel2013.tlh 生成错误。
问题是 cx_excel2013.tlh 试图对“Office2013”中的对象使用“Office2010”命名空间,这会导致构建失败。 例如,enum Office2010::MsoTriState LinkToFile 正在生成,导致构建失败。
谁能解释正在发生的事情或正在发生的事情以及如何克服这个问题(不将#imports返回给CPP)??? 另外,我想只生成 TLH/TLI 并一起删除导入,因为它们不会改变,但感觉不对,我没有解决真正的问题。
谢谢!
STDAFX.CPP:
// Office 2010
#import "..\lib\tlb\office\MSO2010.tlb" rename_namespace("Office2010") rename("RGB","msoRGB") rename("SearchPath", "msoSearchPath") rename("DocumentProperties", "msoDocumentProperties")
#import "..\lib\tlb\office\VBE6EXT2010.tlb" rename_namespace("VBE6EXT2010") rename("Property", "vbeProperty")
#pragma warning(disable: 4192)
#import "..\lib\tlb\office\excel2010.tlb" rename_namespace("Excel2010") rename("VBE6", "VBE6EXT2010") rename("RGB","excelRGB") rename("DialogBox","excelDialogBox") rename("CopyFile","excelCopyFile") rename("ReplaceText","excelReplaceText") rename("Property", "excelProperty") no_function_mapping
#import "..\lib\tlb\office\msppt2010.tlb" rename_namespace("PowerPoint2010") rename("VBE6", "VBE6EXT2010") rename("RGB","pptRGB") rename("Property", "pptProperty") no_function_mapping
#import "..\lib\tlb\office\MSWORD2010.tlb" rename_namespace("Word2010") rename("VBE6", "VBE6EXT2010") rename("ExitWindows","wordExitWindows") rename("FindText","FindText1") rename("RGB", "wordRGB") no_function_mapping
#pragma warning(default: 4192)
// Office 2013
#import "..\lib\tlb\office\MSO2013.tlb" rename_namespace("Office2013") rename("RGB","msoRGB") rename("SearchPath", "msoSearchPath") rename("DocumentProperties", "msoDocumentProperties")
#import "..\lib\tlb\office\VBE6EXT2013.tlb" rename_namespace("VBE6EXT2013") rename("Property", "vbeProperty")
#pragma warning(disable: 4192)
#import "..\lib\tlb\office\excel2013.tlb" rename_namespace("Excel2013") rename("VBE6", "VBE6EXT2013") rename("RGB","excelRGB") rename("DialogBox","excelDialogBox") rename("CopyFile","excelCopyFile") rename("ReplaceText","excelReplaceText") rename("Property", "excelProperty") no_function_mapping
#import "..\lib\tlb\office\msppt2013.tlb" rename_namespace("PowerPoint2013") rename("VBE6", "VBE6EXT2013") rename("RGB","pptRGB") rename("Property", "pptProperty") no_function_mapping
#import "..\lib\tlb\office\MSWORD2013.tlb" rename_namespace("Word2013") rename("VBE6", "VBE6EXT2013") rename("ExitWindows","wordExitWindows") rename("FindText","FindText1") rename("RGB", "wordRGB") no_function_mapping
#pragma warning(default: 4192)
// Office 2016
#import "..\lib\tlb\office\MSO2016.tlb" rename_namespace("Office2016") rename("RGB","msoRGB") rename("SearchPath", "msoSearchPath") rename("DocumentProperties", "msoDocumentProperties")
#import "..\lib\tlb\office\VBE6EXT2016.tlb" rename_namespace("VBE6EXT2016") rename("Property", "vbeProperty")
#pragma warning(disable: 4192)
#import "..\lib\tlb\office\excel2016.tlb" rename_namespace("Excel2016") rename("VBE6", "VBE6EXT2016") rename("RGB","excelRGB") rename("DialogBox","excelDialogBox") rename("CopyFile","excelCopyFile") rename("ReplaceText","excelReplaceText") rename("Property", "excelProperty") no_function_mapping
#import "..\lib\tlb\office\msppt2016.tlb" rename_namespace("PowerPoint2016") rename("VBE6", "VBE6EXT2016") rename("RGB","pptRGB") rename("Property", "pptProperty") no_function_mapping
#import "..\lib\tlb\office\MSWORD2016.tlb" rename_namespace("Word2016") rename("VBE6", "VBE6EXT2016") rename("ExitWindows","wordExitWindows") rename("FindText","FindText1") rename("RGB", "wordRGB") no_function_mapping
#pragma warning(default: 4192)
编辑: 我应该补充一点,构建失败并且没有生成其他 TLH/TLI。
【问题讨论】:
【参考方案1】:问题是所有的 office 版本都使用相同的 GUID,唯一的区别是版本,#import 指令忽略了它。
这就是为什么在构建 Excel2013.tlh/tli 时使用 Office2010(第一个 office TLB),因为它正在寻找的 GUID 已经定义,因此它可以忽略 Office2013。从VS的角度来看,是一样的。
接口向后兼容,因此解决方案只是导入 2016。缺点是 Office2010/2013 代码可以尝试使用它并不真正支持的代码(运行时失败)。
【讨论】:
以上是关于#import 生成不正确的 TLH 文件的主要内容,如果未能解决你的问题,请参考以下文章