Win32 API 日本語リファレンス
ホームStorage.Packaging.Appx › AddPackageDependency2

AddPackageDependency2

関数
オプションを指定しパッケージ依存関係をグラフに追加する。
DLLapi-ms-win-appmodel-runtime-l1-1-7.dll呼出規約winapi

シグネチャ

// api-ms-win-appmodel-runtime-l1-1-7.dll
#include <windows.h>

HRESULT AddPackageDependency2(
    LPCWSTR packageDependencyId,
    INT rank,
    AddPackageDependencyOptions2 options,
    PACKAGEDEPENDENCY_CONTEXT* packageDependencyContext,
    LPWSTR* packageFullName   // optional
);

パラメーター

名前方向
packageDependencyIdLPCWSTRin
rankINTin
optionsAddPackageDependencyOptions2in
packageDependencyContextPACKAGEDEPENDENCY_CONTEXT*out
packageFullNameLPWSTR*outoptional

戻り値の型: HRESULT

各言語での呼び出し定義

// api-ms-win-appmodel-runtime-l1-1-7.dll
#include <windows.h>

HRESULT AddPackageDependency2(
    LPCWSTR packageDependencyId,
    INT rank,
    AddPackageDependencyOptions2 options,
    PACKAGEDEPENDENCY_CONTEXT* packageDependencyContext,
    LPWSTR* packageFullName   // optional
);
[DllImport("api-ms-win-appmodel-runtime-l1-1-7.dll", ExactSpelling = true)]
static extern int AddPackageDependency2(
    [MarshalAs(UnmanagedType.LPWStr)] string packageDependencyId,   // LPCWSTR
    int rank,   // INT
    int options,   // AddPackageDependencyOptions2
    IntPtr packageDependencyContext,   // PACKAGEDEPENDENCY_CONTEXT* out
    IntPtr packageFullName   // LPWSTR* optional, out
);
<DllImport("api-ms-win-appmodel-runtime-l1-1-7.dll", ExactSpelling:=True)>
Public Shared Function AddPackageDependency2(
    <MarshalAs(UnmanagedType.LPWStr)> packageDependencyId As String,   ' LPCWSTR
    rank As Integer,   ' INT
    options As Integer,   ' AddPackageDependencyOptions2
    packageDependencyContext As IntPtr,   ' PACKAGEDEPENDENCY_CONTEXT* out
    packageFullName As IntPtr   ' LPWSTR* optional, out
) As Integer
End Function
' packageDependencyId : LPCWSTR
' rank : INT
' options : AddPackageDependencyOptions2
' packageDependencyContext : PACKAGEDEPENDENCY_CONTEXT* out
' packageFullName : LPWSTR* optional, out
Declare PtrSafe Function AddPackageDependency2 Lib "api-ms-win-appmodel-runtime-l1-1-7" ( _
    ByVal packageDependencyId As LongPtr, _
    ByVal rank As Long, _
    ByVal options As Long, _
    ByVal packageDependencyContext As LongPtr, _
    ByVal packageFullName As LongPtr) As Long
' VBA7前提(PtrSafe)。32bit Office では LongPtr→Long。Integer=16bit / Long=32bit / LongLong=64bit。
import ctypes
from ctypes import wintypes

AddPackageDependency2 = ctypes.windll.LoadLibrary("api-ms-win-appmodel-runtime-l1-1-7.dll").AddPackageDependency2
AddPackageDependency2.restype = ctypes.c_int
AddPackageDependency2.argtypes = [
    wintypes.LPCWSTR,  # packageDependencyId : LPCWSTR
    ctypes.c_int,  # rank : INT
    ctypes.c_int,  # options : AddPackageDependencyOptions2
    ctypes.c_void_p,  # packageDependencyContext : PACKAGEDEPENDENCY_CONTEXT* out
    ctypes.c_void_p,  # packageFullName : LPWSTR* optional, out
]
require 'fiddle'
require 'fiddle/import'

lib = Fiddle.dlopen('api-ms-win-appmodel-runtime-l1-1-7.dll')
AddPackageDependency2 = Fiddle::Function.new(
  lib['AddPackageDependency2'],
  [
    Fiddle::TYPE_VOIDP,  # packageDependencyId : LPCWSTR
    Fiddle::TYPE_INT,  # rank : INT
    Fiddle::TYPE_INT,  # options : AddPackageDependencyOptions2
    Fiddle::TYPE_VOIDP,  # packageDependencyContext : PACKAGEDEPENDENCY_CONTEXT* out
    Fiddle::TYPE_VOIDP,  # packageFullName : LPWSTR* optional, out
  ],
  Fiddle::TYPE_INT)
#[link(name = "api-ms-win-appmodel-runtime-l1-1-7")]
extern "system" {
    fn AddPackageDependency2(
        packageDependencyId: *const u16,  // LPCWSTR
        rank: i32,  // INT
        options: i32,  // AddPackageDependencyOptions2
        packageDependencyContext: *mut *mut core::ffi::c_void,  // PACKAGEDEPENDENCY_CONTEXT* out
        packageFullName: *mut *mut u16  // LPWSTR* optional, out
    ) -> i32;
}
// crates: windows-sys provides ready-made bindings for this API.
$sig = @"
[DllImport("api-ms-win-appmodel-runtime-l1-1-7.dll")]
public static extern int AddPackageDependency2([MarshalAs(UnmanagedType.LPWStr)] string packageDependencyId, int rank, int options, IntPtr packageDependencyContext, IntPtr packageFullName);
"@
$api = Add-Type -MemberDefinition $sig -Name 'api-ms-win-appmodel-runtime-l1-1-7_AddPackageDependency2' -Namespace Win32 -PassThru
# $api::AddPackageDependency2(packageDependencyId, rank, options, packageDependencyContext, packageFullName)
#uselib "api-ms-win-appmodel-runtime-l1-1-7.dll"
#func global AddPackageDependency2 "AddPackageDependency2" sptr, sptr, sptr, sptr, sptr
; AddPackageDependency2 packageDependencyId, rank, options, packageDependencyContext, varptr(packageFullName)   ; 戻り値は stat
; packageDependencyId : LPCWSTR -> "sptr"
; rank : INT -> "sptr"
; options : AddPackageDependencyOptions2 -> "sptr"
; packageDependencyContext : PACKAGEDEPENDENCY_CONTEXT* out -> "sptr"
; packageFullName : LPWSTR* optional, out -> "sptr"
; ※HSP3.7は #func のため戻り値はシステム変数 stat に格納されます。
出力引数:
#uselib "api-ms-win-appmodel-runtime-l1-1-7.dll"
#cfunc global AddPackageDependency2 "AddPackageDependency2" wstr, int, int, sptr, var
; res = AddPackageDependency2(packageDependencyId, rank, options, packageDependencyContext, packageFullName)
; packageDependencyId : LPCWSTR -> "wstr"
; rank : INT -> "int"
; options : AddPackageDependencyOptions2 -> "int"
; packageDependencyContext : PACKAGEDEPENDENCY_CONTEXT* out -> "sptr"
; packageFullName : LPWSTR* optional, out -> "var"
; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。
出力引数:
; HRESULT AddPackageDependency2(LPCWSTR packageDependencyId, INT rank, AddPackageDependencyOptions2 options, PACKAGEDEPENDENCY_CONTEXT* packageDependencyContext, LPWSTR* packageFullName)
#uselib "api-ms-win-appmodel-runtime-l1-1-7.dll"
#cfunc global AddPackageDependency2 "AddPackageDependency2" wstr, int, int, intptr, var
; res = AddPackageDependency2(packageDependencyId, rank, options, packageDependencyContext, packageFullName)
; packageDependencyId : LPCWSTR -> "wstr"
; rank : INT -> "int"
; options : AddPackageDependencyOptions2 -> "int"
; packageDependencyContext : PACKAGEDEPENDENCY_CONTEXT* out -> "intptr"
; packageFullName : LPWSTR* optional, out -> "var"
; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。
import (
	"golang.org/x/sys/windows"
	"unsafe"
)

var (
	api_ms_win_appmodel_runtime_l1_1_7 = windows.NewLazySystemDLL("api-ms-win-appmodel-runtime-l1-1-7.dll")
	procAddPackageDependency2 = api_ms_win_appmodel_runtime_l1_1_7.NewProc("AddPackageDependency2")
)

// packageDependencyId (LPCWSTR), rank (INT), options (AddPackageDependencyOptions2), packageDependencyContext (PACKAGEDEPENDENCY_CONTEXT* out), packageFullName (LPWSTR* optional, out)
r1, _, err := procAddPackageDependency2.Call(
	uintptr(unsafe.Pointer(windows.StringToUTF16Ptr(packageDependencyId))),
	uintptr(rank),
	uintptr(options),
	uintptr(packageDependencyContext),
	uintptr(packageFullName),
)
_ = err  // syscall.Errno (valid when the call sets last-error)
_ = r1   // HRESULT
function AddPackageDependency2(
  packageDependencyId: PWideChar;   // LPCWSTR
  rank: Integer;   // INT
  options: Integer;   // AddPackageDependencyOptions2
  packageDependencyContext: Pointer;   // PACKAGEDEPENDENCY_CONTEXT* out
  packageFullName: PPWideChar   // LPWSTR* optional, out
): Integer; stdcall;
  external 'api-ms-win-appmodel-runtime-l1-1-7.dll' name 'AddPackageDependency2';
result := DllCall("api-ms-win-appmodel-runtime-l1-1-7\AddPackageDependency2"
    , "WStr", packageDependencyId   ; LPCWSTR
    , "Int", rank   ; INT
    , "Int", options   ; AddPackageDependencyOptions2
    , "Ptr", packageDependencyContext   ; PACKAGEDEPENDENCY_CONTEXT* out
    , "Ptr", packageFullName   ; LPWSTR* optional, out
    , "Int")   ; return: HRESULT
●AddPackageDependency2(packageDependencyId, rank, options, packageDependencyContext, packageFullName) = DLL("api-ms-win-appmodel-runtime-l1-1-7.dll", "int AddPackageDependency2(char*, int, int, void*, void*)")
# 呼び出し: AddPackageDependency2(packageDependencyId, rank, options, packageDependencyContext, packageFullName)
# packageDependencyId : LPCWSTR -> "char*"
# rank : INT -> "int"
# options : AddPackageDependencyOptions2 -> "int"
# packageDependencyContext : PACKAGEDEPENDENCY_CONTEXT* out -> "void*"
# packageFullName : LPWSTR* optional, out -> "void*"
# なでしこ1は32bit・ANSI(Shift_JIS)。文字列=char*(ANSI)、ポインタ/ハンドル=void*(4byte)。