我有两个不同的项目C++,一个编译为静态库并使用Unicode字符编码,因为它必须支持多种语言(拼写检查器),另一个是使用MultiByteCharacterSet编码的传统MFC项目。
旧项目必须使用库项目(以交互方式对 richedit 控件的内容进行拼写检查)。
当我使用 richEdit 控件构建一个单独的项目时,将字符编码设置为 Unicode 并引用库,它工作正常。 但是当我尝试以与单独项目相同的方式从旧项目中引用库时,它不起作用。
我调查并意识到EM_GETTEXTRANGE填充的 TEXTRANGE 结构需要在其 lpstrtext 成员中有一个 Unicode 值,而遗留项目并非如此。 库中的实现如下:
TEXTRANGE txtRange;
memset (&txtRange, 0, sizeof(txtRange));
memset (bufW, 0, sizeof (bufW));
//debug_log("Size of TEXTRANGE: x: %d and Size of BufW: %d.", sizeof(txtRange), sizeof(bufW));
txtRange.lpstrText = string_from_unicode_cp(bufW, CP_ACP);
txtRange.chrg.cpMin = 0;
txtRange.chrg.cpMax = _countof(bufW);
debug_log("count of bufw: %s.", bufW);
SendMessage (hwnd, EM_GETTEXTRANGE, 0, (LPARAM)&txtRange);
debug_log("txtRange.lpstrText is: %S",txtRange.lpstrText);
但我收到错误:
SpellChecker.cpp(215): error C2440: '=' : cannot convert from 'char *' to 'LPWSTR'
Types pointed to are unrelated; conversion requires reinterpret_cast, C-style cast or function-style cast
Visual Studio说库中的lpstrtext成员是LPWSTR(可能是因为选择了UNICODE格式),这是可以理解的。
我的问题是,有没有办法强制 lpstrtext 成员期望 LPSTR(强制转换),即使包含它的项目设置为使用 unicode。
TEXTRANGE
是一个宏:
#ifdef UNICODE
#define TEXTRANGE TEXTRANGEW
#else
#define TEXTRANGE TEXTRANGEA
#endif // UNICODE
因此,您应该能够使用TEXTRANGEA
来强制char*
类型。