如何在Mingw Gcc中声明和链接RoInitialize,RoUninitialize,RoGetActivatio
How to declare and link to RoInitialize,RoUninitialize,RoGetActivationFactory and HSTRING Functions in Mingw Gcc
更新:添加了RoInitialize
在roapi.h中的样子
我正在写一个纯c++ 11 WinRT库。我不使用WRL或c++/CX(显然,如果我想要纯c++ 11)。
我得到了我的代码在MSVC上编译和运行,但我想看看我是否能得到代码在Mingw Gcc上编译和运行。具体来说,我正在使用从nuwen.net获得的GCC 4.7.2。
此时我需要的是一种方法来调用Windows API函数RoInitialize
, RoUnitialize
, RoGetActivationFactory
和HSTRING
函数WindowsCreateString
, WindowsDuplicateString
, WindowsDeleteString
。
我试着用g++编译这个程序,但是得到了错误
extern "C"{
__declspec(dllimport)int __stdcall RoInitialize(int);
}
int main(){
RoInitialize(1);
}
我试图编译,但得到:
c:UsersjrbDesktop>g++ gccwinrt.cpp
C:UsersjrbAppDataLocalTempccy7y1V9.o:gccwinrt.cpp:(.text+0x1e): undefined
reference to `_imp__RoInitialize@4'
collect2.exe: error: ld returned 1 exit status
如果有人能指出我在正确的方向上如何声明这些函数和我需要链接到哪些库,我将不胜感激。即使它需要LoadLibrary
/GetProcAddress
,我仍然可以接受
更新:这是RoInitialize
看起来像头roapi.h
ROAPI
_Check_return_
HRESULT
WINAPI
RoInitialize(
_In_ RO_INIT_TYPE initType
);
ROAPI is just a define for __declspec(dllimport)
_Check_return_ is part of SAL (Secure Annotations Language?)
HRESULT maps to int32
WINAPI is a define for __stdcall
RO_INIT_TYPE is an enumeration so int should cover it
这些函数的导入库是runtimeobject.lib
(MSDN文档没有提到)。它可以在Windows 8的Windows SDK中找到。
您需要链接的库是windowsapp.lib
(并且只有这个库,删除所有其他库)。
本主题列出了UWP (Universal Windows Platform)中所有Windows 10设备都可以实现的Win32 api。为方便起见,一个名为WindowsApp的伞形库。Microsoft Windows软件开发工具包(SDK)提供了lib,它为这组Win32 api提供了导出。将您的应用程序与WindowsApp链接。
所有Windows 10设备上的api - Microsoft Docs
请参阅该页以获得实现;它包括RoInitialize
, RoUnitialize
, RoGetActivationFactory
和WindowsCreateString
, WindowsDuplicateString
, &WindowsDeleteString
(在许多,许多其他)。如果您需要其他函数,您可能还需要链接扩展api。
最初也有类似的指导https://msdn.microsoft.com/en-gb/windows/uwp/get-started/universal-application-platform-guide#writing-code但已不存在:
Windowsapp。Lib是一把"伞"。lib,它提供了UWP api的导出。链接到Windowsapp。lib将添加到您的应用程序对所有Windows 10设备系列上存在的dll的依赖。
对于延迟加载,您需要加载api-ms-win-core-winrt-l1-1-0.dll
,这是一个API集,无论实际dll在哪里,Windows都可以加载的API集合。这个特定的集合被列为Windows 8.1 API集合,但是如果你检查RoInitialize的文档,它会说最小支持的客户端是Windows 8。假设您使用LoadLibrary
和GetProcAddress
,这应该无关紧要。
该方法实际实现的DLL是combase.dll
,但是他们使用这些API集DLL作为间接级别,以便他们将来可以自由地更改或更新原始DLL。
为了将来参考,Windows 10 (UWP)的API集在Windows 8(和8.1)的API集的单独页面上列出。存根DLL(用于延迟加载)是相同的。https://msdn.microsoft.com/library/windows/desktop/mt186421
许多其他API也在自己的文档中列出了相应的API集。例如,MSDN给出了AllowSetForeground作为一个例子。
如果你没有包含RoInitialize的导入库,你需要使用LoadLibrary/GetProcAddress来解析类型
运行时链接如下:
#include <roapi.h>
namespace
{
FARPROC LoadComBaseFunction(const char* function_name)
{
static HMODULE const handle = ::LoadLibraryA("combase.dll");
return handle ? ::GetProcAddress(handle, function_name) : nullptr;
}
decltype(&::RoInitialize) GetRoInitializeFunction()
{
static decltype(&::RoInitialize) const function = reinterpret_cast<decltype(&::RoInitialize)>(LoadComBaseFunction("RoInitialize"));
return function;
}
}
HRESULT RoInitialize(RO_INIT_TYPE init_type)
{
auto ro_initialize_func = GetRoInitializeFunction();
if (!ro_initialize_func)
return E_FAIL;
return ro_initialize_func(init_type);
}
源- lambda参数转换为constexpr技巧,然后获取带链接的数组
- CMake-按正确顺序将项目与C运行时对象文件链接
- 从链接列表c++中删除一个项目
- 有根的二进制搜索树.保留与其父级的链接
- 读取文件的最后一行并输入到链接列表时出错
- 静态数据成员的问题-修复链接错误会导致编译器错误
- node-gyp 在 macOS 上未正确链接库
- 基于boost的程序的静态链接——zlib问题
- 无法链接 CMake 中的本地库
- 内联函数中具有内部链接的全局变量
- 链接阶段在Ubuntu上失败,但在MacOS上失败
- 使用gcc从静态链接的文件中查找可选符号
- 我可以将一个用clang c++11编译的对象与另一个用c++17编译的对象链接起来吗
- 将--whole archive链接器选项与CMake和具有其他库依赖项的库一起使用
- 下面是我为检测链接列表中的循环而制作的代码
- 有了gcc,是否可以链接库,但前提是它存在
- 使用C链接在函数内部创建C++模板
- Visual Studio mkl_link_tool.exe链接错误
- 尝试链接我的着色器时,我收到错误代码"error c5145 must write to gl_position"
- 如何在Mingw Gcc中声明和链接RoInitialize,RoUninitialize,RoGetActivatio