Win32 API 日本語リファレンス
ホームUI.Shell.PropertiesSystem › SHPropStgWriteMultiple

SHPropStgWriteMultiple

関数
プロパティ記憶域に複数の値を書き込む。
DLLSHELL32.dll呼出規約winapi対応OSWindows XP 以降

シグネチャ

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

HRESULT SHPropStgWriteMultiple(
    IPropertyStorage* pps,
    DWORD* puCodePage,   // optional
    DWORD cpspec,
    const PROPSPEC* rgpspec,
    PROPVARIANT* rgvar,
    DWORD propidNameFirst
);

パラメーター

名前方向
ppsIPropertyStorage*in
puCodePageDWORD*inoutoptional
cpspecDWORDin
rgpspecPROPSPEC*in
rgvarPROPVARIANT*inout
propidNameFirstDWORDin

戻り値の型: HRESULT

各言語での呼び出し定義

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

HRESULT SHPropStgWriteMultiple(
    IPropertyStorage* pps,
    DWORD* puCodePage,   // optional
    DWORD cpspec,
    const PROPSPEC* rgpspec,
    PROPVARIANT* rgvar,
    DWORD propidNameFirst
);
[DllImport("SHELL32.dll", ExactSpelling = true)]
static extern int SHPropStgWriteMultiple(
    IntPtr pps,   // IPropertyStorage*
    IntPtr puCodePage,   // DWORD* optional, in/out
    uint cpspec,   // DWORD
    IntPtr rgpspec,   // PROPSPEC*
    IntPtr rgvar,   // PROPVARIANT* in/out
    uint propidNameFirst   // DWORD
);
<DllImport("SHELL32.dll", ExactSpelling:=True)>
Public Shared Function SHPropStgWriteMultiple(
    pps As IntPtr,   ' IPropertyStorage*
    puCodePage As IntPtr,   ' DWORD* optional, in/out
    cpspec As UInteger,   ' DWORD
    rgpspec As IntPtr,   ' PROPSPEC*
    rgvar As IntPtr,   ' PROPVARIANT* in/out
    propidNameFirst As UInteger   ' DWORD
) As Integer
End Function
' pps : IPropertyStorage*
' puCodePage : DWORD* optional, in/out
' cpspec : DWORD
' rgpspec : PROPSPEC*
' rgvar : PROPVARIANT* in/out
' propidNameFirst : DWORD
Declare PtrSafe Function SHPropStgWriteMultiple Lib "shell32" ( _
    ByVal pps As LongPtr, _
    ByVal puCodePage As LongPtr, _
    ByVal cpspec As Long, _
    ByVal rgpspec As LongPtr, _
    ByVal rgvar As LongPtr, _
    ByVal propidNameFirst As Long) As Long
' VBA7前提(PtrSafe)。32bit Office では LongPtr→Long。Integer=16bit / Long=32bit / LongLong=64bit。
import ctypes
from ctypes import wintypes

SHPropStgWriteMultiple = ctypes.windll.shell32.SHPropStgWriteMultiple
SHPropStgWriteMultiple.restype = ctypes.c_int
SHPropStgWriteMultiple.argtypes = [
    ctypes.c_void_p,  # pps : IPropertyStorage*
    ctypes.POINTER(wintypes.DWORD),  # puCodePage : DWORD* optional, in/out
    wintypes.DWORD,  # cpspec : DWORD
    ctypes.c_void_p,  # rgpspec : PROPSPEC*
    ctypes.c_void_p,  # rgvar : PROPVARIANT* in/out
    wintypes.DWORD,  # propidNameFirst : DWORD
]
require 'fiddle'
require 'fiddle/import'

lib = Fiddle.dlopen('SHELL32.dll')
SHPropStgWriteMultiple = Fiddle::Function.new(
  lib['SHPropStgWriteMultiple'],
  [
    Fiddle::TYPE_VOIDP,  # pps : IPropertyStorage*
    Fiddle::TYPE_VOIDP,  # puCodePage : DWORD* optional, in/out
    -Fiddle::TYPE_INT,  # cpspec : DWORD
    Fiddle::TYPE_VOIDP,  # rgpspec : PROPSPEC*
    Fiddle::TYPE_VOIDP,  # rgvar : PROPVARIANT* in/out
    -Fiddle::TYPE_INT,  # propidNameFirst : DWORD
  ],
  Fiddle::TYPE_INT)
#[link(name = "shell32")]
extern "system" {
    fn SHPropStgWriteMultiple(
        pps: *mut core::ffi::c_void,  // IPropertyStorage*
        puCodePage: *mut u32,  // DWORD* optional, in/out
        cpspec: u32,  // DWORD
        rgpspec: *const PROPSPEC,  // PROPSPEC*
        rgvar: *mut PROPVARIANT,  // PROPVARIANT* in/out
        propidNameFirst: u32  // DWORD
    ) -> i32;
}
// crates: windows-sys provides ready-made bindings for this API.
$sig = @"
[DllImport("SHELL32.dll")]
public static extern int SHPropStgWriteMultiple(IntPtr pps, IntPtr puCodePage, uint cpspec, IntPtr rgpspec, IntPtr rgvar, uint propidNameFirst);
"@
$api = Add-Type -MemberDefinition $sig -Name 'SHELL32_SHPropStgWriteMultiple' -Namespace Win32 -PassThru
# $api::SHPropStgWriteMultiple(pps, puCodePage, cpspec, rgpspec, rgvar, propidNameFirst)
#uselib "SHELL32.dll"
#func global SHPropStgWriteMultiple "SHPropStgWriteMultiple" sptr, sptr, sptr, sptr, sptr, sptr
; SHPropStgWriteMultiple pps, varptr(puCodePage), cpspec, varptr(rgpspec), varptr(rgvar), propidNameFirst   ; 戻り値は stat
; pps : IPropertyStorage* -> "sptr"
; puCodePage : DWORD* optional, in/out -> "sptr"
; cpspec : DWORD -> "sptr"
; rgpspec : PROPSPEC* -> "sptr"
; rgvar : PROPVARIANT* in/out -> "sptr"
; propidNameFirst : DWORD -> "sptr"
; ※HSP3.7は #func のため戻り値はシステム変数 stat に格納されます。
出力引数:
#uselib "SHELL32.dll"
#cfunc global SHPropStgWriteMultiple "SHPropStgWriteMultiple" sptr, var, int, var, var, int
; res = SHPropStgWriteMultiple(pps, puCodePage, cpspec, rgpspec, rgvar, propidNameFirst)
; pps : IPropertyStorage* -> "sptr"
; puCodePage : DWORD* optional, in/out -> "var"
; cpspec : DWORD -> "int"
; rgpspec : PROPSPEC* -> "var"
; rgvar : PROPVARIANT* in/out -> "var"
; propidNameFirst : DWORD -> "int"
; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。
出力引数:
; HRESULT SHPropStgWriteMultiple(IPropertyStorage* pps, DWORD* puCodePage, DWORD cpspec, PROPSPEC* rgpspec, PROPVARIANT* rgvar, DWORD propidNameFirst)
#uselib "SHELL32.dll"
#cfunc global SHPropStgWriteMultiple "SHPropStgWriteMultiple" intptr, var, int, var, var, int
; res = SHPropStgWriteMultiple(pps, puCodePage, cpspec, rgpspec, rgvar, propidNameFirst)
; pps : IPropertyStorage* -> "intptr"
; puCodePage : DWORD* optional, in/out -> "var"
; cpspec : DWORD -> "int"
; rgpspec : PROPSPEC* -> "var"
; rgvar : PROPVARIANT* in/out -> "var"
; propidNameFirst : DWORD -> "int"
; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。
import (
	"golang.org/x/sys/windows"
	"unsafe"
)

var (
	shell32 = windows.NewLazySystemDLL("SHELL32.dll")
	procSHPropStgWriteMultiple = shell32.NewProc("SHPropStgWriteMultiple")
)

// pps (IPropertyStorage*), puCodePage (DWORD* optional, in/out), cpspec (DWORD), rgpspec (PROPSPEC*), rgvar (PROPVARIANT* in/out), propidNameFirst (DWORD)
r1, _, err := procSHPropStgWriteMultiple.Call(
	uintptr(pps),
	uintptr(puCodePage),
	uintptr(cpspec),
	uintptr(rgpspec),
	uintptr(rgvar),
	uintptr(propidNameFirst),
)
_ = err  // syscall.Errno (valid when the call sets last-error)
_ = r1   // HRESULT
function SHPropStgWriteMultiple(
  pps: Pointer;   // IPropertyStorage*
  puCodePage: Pointer;   // DWORD* optional, in/out
  cpspec: DWORD;   // DWORD
  rgpspec: Pointer;   // PROPSPEC*
  rgvar: Pointer;   // PROPVARIANT* in/out
  propidNameFirst: DWORD   // DWORD
): Integer; stdcall;
  external 'SHELL32.dll' name 'SHPropStgWriteMultiple';
result := DllCall("SHELL32\SHPropStgWriteMultiple"
    , "Ptr", pps   ; IPropertyStorage*
    , "Ptr", puCodePage   ; DWORD* optional, in/out
    , "UInt", cpspec   ; DWORD
    , "Ptr", rgpspec   ; PROPSPEC*
    , "Ptr", rgvar   ; PROPVARIANT* in/out
    , "UInt", propidNameFirst   ; DWORD
    , "Int")   ; return: HRESULT
●SHPropStgWriteMultiple(pps, puCodePage, cpspec, rgpspec, rgvar, propidNameFirst) = DLL("SHELL32.dll", "int SHPropStgWriteMultiple(void*, void*, dword, void*, void*, dword)")
# 呼び出し: SHPropStgWriteMultiple(pps, puCodePage, cpspec, rgpspec, rgvar, propidNameFirst)
# pps : IPropertyStorage* -> "void*"
# puCodePage : DWORD* optional, in/out -> "void*"
# cpspec : DWORD -> "dword"
# rgpspec : PROPSPEC* -> "void*"
# rgvar : PROPVARIANT* in/out -> "void*"
# propidNameFirst : DWORD -> "dword"
# なでしこ1は32bit・ANSI(Shift_JIS)。文字列=char*(ANSI)、ポインタ/ハンドル=void*(4byte)。