Win32 API 日本語リファレンス
ホームSystem.Com.StructuredStorage › CoGetInstanceFromFile

CoGetInstanceFromFile

関数
指定ファイルで初期化したCOMオブジェクトを生成しインターフェイスを取得する。
DLLOLE32.dll呼出規約winapi対応OSWindows 2000 以降

シグネチャ

// OLE32.dll
#include <windows.h>

HRESULT CoGetInstanceFromFile(
    COSERVERINFO* pServerInfo,   // optional
    GUID* pClsid,   // optional
    IUnknown* punkOuter,   // optional
    CLSCTX dwClsCtx,
    DWORD grfMode,
    LPWSTR pwszName,
    DWORD dwCount,
    MULTI_QI* pResults
);

パラメーター

名前方向
pServerInfoCOSERVERINFO*inoptional
pClsidGUID*inoptional
punkOuterIUnknown*inoptional
dwClsCtxCLSCTXin
grfModeDWORDin
pwszNameLPWSTRin
dwCountDWORDin
pResultsMULTI_QI*inout

戻り値の型: HRESULT

各言語での呼び出し定義

// OLE32.dll
#include <windows.h>

HRESULT CoGetInstanceFromFile(
    COSERVERINFO* pServerInfo,   // optional
    GUID* pClsid,   // optional
    IUnknown* punkOuter,   // optional
    CLSCTX dwClsCtx,
    DWORD grfMode,
    LPWSTR pwszName,
    DWORD dwCount,
    MULTI_QI* pResults
);
[DllImport("OLE32.dll", ExactSpelling = true)]
static extern int CoGetInstanceFromFile(
    IntPtr pServerInfo,   // COSERVERINFO* optional
    IntPtr pClsid,   // GUID* optional
    IntPtr punkOuter,   // IUnknown* optional
    uint dwClsCtx,   // CLSCTX
    uint grfMode,   // DWORD
    [MarshalAs(UnmanagedType.LPWStr)] string pwszName,   // LPWSTR
    uint dwCount,   // DWORD
    IntPtr pResults   // MULTI_QI* in/out
);
<DllImport("OLE32.dll", ExactSpelling:=True)>
Public Shared Function CoGetInstanceFromFile(
    pServerInfo As IntPtr,   ' COSERVERINFO* optional
    pClsid As IntPtr,   ' GUID* optional
    punkOuter As IntPtr,   ' IUnknown* optional
    dwClsCtx As UInteger,   ' CLSCTX
    grfMode As UInteger,   ' DWORD
    <MarshalAs(UnmanagedType.LPWStr)> pwszName As String,   ' LPWSTR
    dwCount As UInteger,   ' DWORD
    pResults As IntPtr   ' MULTI_QI* in/out
) As Integer
End Function
' pServerInfo : COSERVERINFO* optional
' pClsid : GUID* optional
' punkOuter : IUnknown* optional
' dwClsCtx : CLSCTX
' grfMode : DWORD
' pwszName : LPWSTR
' dwCount : DWORD
' pResults : MULTI_QI* in/out
Declare PtrSafe Function CoGetInstanceFromFile Lib "ole32" ( _
    ByVal pServerInfo As LongPtr, _
    ByVal pClsid As LongPtr, _
    ByVal punkOuter As LongPtr, _
    ByVal dwClsCtx As Long, _
    ByVal grfMode As Long, _
    ByVal pwszName As LongPtr, _
    ByVal dwCount As Long, _
    ByVal pResults As LongPtr) As Long
' VBA7前提(PtrSafe)。32bit Office では LongPtr→Long。Integer=16bit / Long=32bit / LongLong=64bit。
import ctypes
from ctypes import wintypes

CoGetInstanceFromFile = ctypes.windll.ole32.CoGetInstanceFromFile
CoGetInstanceFromFile.restype = ctypes.c_int
CoGetInstanceFromFile.argtypes = [
    ctypes.c_void_p,  # pServerInfo : COSERVERINFO* optional
    ctypes.c_void_p,  # pClsid : GUID* optional
    ctypes.c_void_p,  # punkOuter : IUnknown* optional
    wintypes.DWORD,  # dwClsCtx : CLSCTX
    wintypes.DWORD,  # grfMode : DWORD
    wintypes.LPCWSTR,  # pwszName : LPWSTR
    wintypes.DWORD,  # dwCount : DWORD
    ctypes.c_void_p,  # pResults : MULTI_QI* in/out
]
require 'fiddle'
require 'fiddle/import'

lib = Fiddle.dlopen('OLE32.dll')
CoGetInstanceFromFile = Fiddle::Function.new(
  lib['CoGetInstanceFromFile'],
  [
    Fiddle::TYPE_VOIDP,  # pServerInfo : COSERVERINFO* optional
    Fiddle::TYPE_VOIDP,  # pClsid : GUID* optional
    Fiddle::TYPE_VOIDP,  # punkOuter : IUnknown* optional
    -Fiddle::TYPE_INT,  # dwClsCtx : CLSCTX
    -Fiddle::TYPE_INT,  # grfMode : DWORD
    Fiddle::TYPE_VOIDP,  # pwszName : LPWSTR
    -Fiddle::TYPE_INT,  # dwCount : DWORD
    Fiddle::TYPE_VOIDP,  # pResults : MULTI_QI* in/out
  ],
  Fiddle::TYPE_INT)
#[link(name = "ole32")]
extern "system" {
    fn CoGetInstanceFromFile(
        pServerInfo: *mut COSERVERINFO,  // COSERVERINFO* optional
        pClsid: *mut GUID,  // GUID* optional
        punkOuter: *mut core::ffi::c_void,  // IUnknown* optional
        dwClsCtx: u32,  // CLSCTX
        grfMode: u32,  // DWORD
        pwszName: *mut u16,  // LPWSTR
        dwCount: u32,  // DWORD
        pResults: *mut MULTI_QI  // MULTI_QI* in/out
    ) -> i32;
}
// crates: windows-sys provides ready-made bindings for this API.
$sig = @"
[DllImport("OLE32.dll")]
public static extern int CoGetInstanceFromFile(IntPtr pServerInfo, IntPtr pClsid, IntPtr punkOuter, uint dwClsCtx, uint grfMode, [MarshalAs(UnmanagedType.LPWStr)] string pwszName, uint dwCount, IntPtr pResults);
"@
$api = Add-Type -MemberDefinition $sig -Name 'OLE32_CoGetInstanceFromFile' -Namespace Win32 -PassThru
# $api::CoGetInstanceFromFile(pServerInfo, pClsid, punkOuter, dwClsCtx, grfMode, pwszName, dwCount, pResults)
#uselib "OLE32.dll"
#func global CoGetInstanceFromFile "CoGetInstanceFromFile" sptr, sptr, sptr, sptr, sptr, sptr, sptr, sptr
; CoGetInstanceFromFile varptr(pServerInfo), varptr(pClsid), punkOuter, dwClsCtx, grfMode, pwszName, dwCount, varptr(pResults)   ; 戻り値は stat
; pServerInfo : COSERVERINFO* optional -> "sptr"
; pClsid : GUID* optional -> "sptr"
; punkOuter : IUnknown* optional -> "sptr"
; dwClsCtx : CLSCTX -> "sptr"
; grfMode : DWORD -> "sptr"
; pwszName : LPWSTR -> "sptr"
; dwCount : DWORD -> "sptr"
; pResults : MULTI_QI* in/out -> "sptr"
; ※HSP3.7は #func のため戻り値はシステム変数 stat に格納されます。
出力引数:
#uselib "OLE32.dll"
#cfunc global CoGetInstanceFromFile "CoGetInstanceFromFile" var, var, sptr, int, int, wstr, int, var
; res = CoGetInstanceFromFile(pServerInfo, pClsid, punkOuter, dwClsCtx, grfMode, pwszName, dwCount, pResults)
; pServerInfo : COSERVERINFO* optional -> "var"
; pClsid : GUID* optional -> "var"
; punkOuter : IUnknown* optional -> "sptr"
; dwClsCtx : CLSCTX -> "int"
; grfMode : DWORD -> "int"
; pwszName : LPWSTR -> "wstr"
; dwCount : DWORD -> "int"
; pResults : MULTI_QI* in/out -> "var"
; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。
出力引数:
; HRESULT CoGetInstanceFromFile(COSERVERINFO* pServerInfo, GUID* pClsid, IUnknown* punkOuter, CLSCTX dwClsCtx, DWORD grfMode, LPWSTR pwszName, DWORD dwCount, MULTI_QI* pResults)
#uselib "OLE32.dll"
#cfunc global CoGetInstanceFromFile "CoGetInstanceFromFile" var, var, intptr, int, int, wstr, int, var
; res = CoGetInstanceFromFile(pServerInfo, pClsid, punkOuter, dwClsCtx, grfMode, pwszName, dwCount, pResults)
; pServerInfo : COSERVERINFO* optional -> "var"
; pClsid : GUID* optional -> "var"
; punkOuter : IUnknown* optional -> "intptr"
; dwClsCtx : CLSCTX -> "int"
; grfMode : DWORD -> "int"
; pwszName : LPWSTR -> "wstr"
; dwCount : DWORD -> "int"
; pResults : MULTI_QI* in/out -> "var"
; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。
import (
	"golang.org/x/sys/windows"
	"unsafe"
)

var (
	ole32 = windows.NewLazySystemDLL("OLE32.dll")
	procCoGetInstanceFromFile = ole32.NewProc("CoGetInstanceFromFile")
)

// pServerInfo (COSERVERINFO* optional), pClsid (GUID* optional), punkOuter (IUnknown* optional), dwClsCtx (CLSCTX), grfMode (DWORD), pwszName (LPWSTR), dwCount (DWORD), pResults (MULTI_QI* in/out)
r1, _, err := procCoGetInstanceFromFile.Call(
	uintptr(pServerInfo),
	uintptr(pClsid),
	uintptr(punkOuter),
	uintptr(dwClsCtx),
	uintptr(grfMode),
	uintptr(unsafe.Pointer(windows.StringToUTF16Ptr(pwszName))),
	uintptr(dwCount),
	uintptr(pResults),
)
_ = err  // syscall.Errno (valid when the call sets last-error)
_ = r1   // HRESULT
function CoGetInstanceFromFile(
  pServerInfo: Pointer;   // COSERVERINFO* optional
  pClsid: PGUID;   // GUID* optional
  punkOuter: Pointer;   // IUnknown* optional
  dwClsCtx: DWORD;   // CLSCTX
  grfMode: DWORD;   // DWORD
  pwszName: PWideChar;   // LPWSTR
  dwCount: DWORD;   // DWORD
  pResults: Pointer   // MULTI_QI* in/out
): Integer; stdcall;
  external 'OLE32.dll' name 'CoGetInstanceFromFile';
result := DllCall("OLE32\CoGetInstanceFromFile"
    , "Ptr", pServerInfo   ; COSERVERINFO* optional
    , "Ptr", pClsid   ; GUID* optional
    , "Ptr", punkOuter   ; IUnknown* optional
    , "UInt", dwClsCtx   ; CLSCTX
    , "UInt", grfMode   ; DWORD
    , "WStr", pwszName   ; LPWSTR
    , "UInt", dwCount   ; DWORD
    , "Ptr", pResults   ; MULTI_QI* in/out
    , "Int")   ; return: HRESULT
●CoGetInstanceFromFile(pServerInfo, pClsid, punkOuter, dwClsCtx, grfMode, pwszName, dwCount, pResults) = DLL("OLE32.dll", "int CoGetInstanceFromFile(void*, void*, void*, dword, dword, char*, dword, void*)")
# 呼び出し: CoGetInstanceFromFile(pServerInfo, pClsid, punkOuter, dwClsCtx, grfMode, pwszName, dwCount, pResults)
# pServerInfo : COSERVERINFO* optional -> "void*"
# pClsid : GUID* optional -> "void*"
# punkOuter : IUnknown* optional -> "void*"
# dwClsCtx : CLSCTX -> "dword"
# grfMode : DWORD -> "dword"
# pwszName : LPWSTR -> "char*"
# dwCount : DWORD -> "dword"
# pResults : MULTI_QI* in/out -> "void*"
# なでしこ1は32bit・ANSI(Shift_JIS)。文字列=char*(ANSI)、ポインタ/ハンドル=void*(4byte)。