Win32 API 日本語リファレンス
ホームNetworkManagement.Rras › MprConfigInterfaceEnum

MprConfigInterfaceEnum

関数
ルーター構成内のインターフェイス一覧を列挙する。
DLLMPRAPI.dll呼出規約winapi対応OSwindowsserver2000

シグネチャ

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

DWORD MprConfigInterfaceEnum(
    HANDLE hMprConfig,
    DWORD dwLevel,
    BYTE** lplpBuffer,
    DWORD dwPrefMaxLen,
    DWORD* lpdwEntriesRead,
    DWORD* lpdwTotalEntries,
    DWORD* lpdwResumeHandle   // optional
);

パラメーター

名前方向
hMprConfigHANDLEin
dwLevelDWORDin
lplpBufferBYTE**out
dwPrefMaxLenDWORDin
lpdwEntriesReadDWORD*out
lpdwTotalEntriesDWORD*out
lpdwResumeHandleDWORD*inoutoptional

戻り値の型: DWORD

各言語での呼び出し定義

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

DWORD MprConfigInterfaceEnum(
    HANDLE hMprConfig,
    DWORD dwLevel,
    BYTE** lplpBuffer,
    DWORD dwPrefMaxLen,
    DWORD* lpdwEntriesRead,
    DWORD* lpdwTotalEntries,
    DWORD* lpdwResumeHandle   // optional
);
[DllImport("MPRAPI.dll", ExactSpelling = true)]
static extern uint MprConfigInterfaceEnum(
    IntPtr hMprConfig,   // HANDLE
    uint dwLevel,   // DWORD
    IntPtr lplpBuffer,   // BYTE** out
    uint dwPrefMaxLen,   // DWORD
    out uint lpdwEntriesRead,   // DWORD* out
    out uint lpdwTotalEntries,   // DWORD* out
    IntPtr lpdwResumeHandle   // DWORD* optional, in/out
);
<DllImport("MPRAPI.dll", ExactSpelling:=True)>
Public Shared Function MprConfigInterfaceEnum(
    hMprConfig As IntPtr,   ' HANDLE
    dwLevel As UInteger,   ' DWORD
    lplpBuffer As IntPtr,   ' BYTE** out
    dwPrefMaxLen As UInteger,   ' DWORD
    <Out> ByRef lpdwEntriesRead As UInteger,   ' DWORD* out
    <Out> ByRef lpdwTotalEntries As UInteger,   ' DWORD* out
    lpdwResumeHandle As IntPtr   ' DWORD* optional, in/out
) As UInteger
End Function
' hMprConfig : HANDLE
' dwLevel : DWORD
' lplpBuffer : BYTE** out
' dwPrefMaxLen : DWORD
' lpdwEntriesRead : DWORD* out
' lpdwTotalEntries : DWORD* out
' lpdwResumeHandle : DWORD* optional, in/out
Declare PtrSafe Function MprConfigInterfaceEnum Lib "mprapi" ( _
    ByVal hMprConfig As LongPtr, _
    ByVal dwLevel As Long, _
    ByVal lplpBuffer As LongPtr, _
    ByVal dwPrefMaxLen As Long, _
    ByRef lpdwEntriesRead As Long, _
    ByRef lpdwTotalEntries As Long, _
    ByVal lpdwResumeHandle As LongPtr) As Long
' VBA7前提(PtrSafe)。32bit Office では LongPtr→Long。Integer=16bit / Long=32bit / LongLong=64bit。
import ctypes
from ctypes import wintypes

MprConfigInterfaceEnum = ctypes.windll.mprapi.MprConfigInterfaceEnum
MprConfigInterfaceEnum.restype = wintypes.DWORD
MprConfigInterfaceEnum.argtypes = [
    wintypes.HANDLE,  # hMprConfig : HANDLE
    wintypes.DWORD,  # dwLevel : DWORD
    ctypes.c_void_p,  # lplpBuffer : BYTE** out
    wintypes.DWORD,  # dwPrefMaxLen : DWORD
    ctypes.POINTER(wintypes.DWORD),  # lpdwEntriesRead : DWORD* out
    ctypes.POINTER(wintypes.DWORD),  # lpdwTotalEntries : DWORD* out
    ctypes.POINTER(wintypes.DWORD),  # lpdwResumeHandle : DWORD* optional, in/out
]
require 'fiddle'
require 'fiddle/import'

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

var (
	mprapi = windows.NewLazySystemDLL("MPRAPI.dll")
	procMprConfigInterfaceEnum = mprapi.NewProc("MprConfigInterfaceEnum")
)

// hMprConfig (HANDLE), dwLevel (DWORD), lplpBuffer (BYTE** out), dwPrefMaxLen (DWORD), lpdwEntriesRead (DWORD* out), lpdwTotalEntries (DWORD* out), lpdwResumeHandle (DWORD* optional, in/out)
r1, _, err := procMprConfigInterfaceEnum.Call(
	uintptr(hMprConfig),
	uintptr(dwLevel),
	uintptr(lplpBuffer),
	uintptr(dwPrefMaxLen),
	uintptr(lpdwEntriesRead),
	uintptr(lpdwTotalEntries),
	uintptr(lpdwResumeHandle),
)
_ = err  // syscall.Errno (valid when the call sets last-error)
_ = r1   // DWORD
function MprConfigInterfaceEnum(
  hMprConfig: THandle;   // HANDLE
  dwLevel: DWORD;   // DWORD
  lplpBuffer: Pointer;   // BYTE** out
  dwPrefMaxLen: DWORD;   // DWORD
  lpdwEntriesRead: Pointer;   // DWORD* out
  lpdwTotalEntries: Pointer;   // DWORD* out
  lpdwResumeHandle: Pointer   // DWORD* optional, in/out
): DWORD; stdcall;
  external 'MPRAPI.dll' name 'MprConfigInterfaceEnum';
result := DllCall("MPRAPI\MprConfigInterfaceEnum"
    , "Ptr", hMprConfig   ; HANDLE
    , "UInt", dwLevel   ; DWORD
    , "Ptr", lplpBuffer   ; BYTE** out
    , "UInt", dwPrefMaxLen   ; DWORD
    , "Ptr", lpdwEntriesRead   ; DWORD* out
    , "Ptr", lpdwTotalEntries   ; DWORD* out
    , "Ptr", lpdwResumeHandle   ; DWORD* optional, in/out
    , "UInt")   ; return: DWORD
●MprConfigInterfaceEnum(hMprConfig, dwLevel, lplpBuffer, dwPrefMaxLen, lpdwEntriesRead, lpdwTotalEntries, lpdwResumeHandle) = DLL("MPRAPI.dll", "dword MprConfigInterfaceEnum(void*, dword, void*, dword, void*, void*, void*)")
# 呼び出し: MprConfigInterfaceEnum(hMprConfig, dwLevel, lplpBuffer, dwPrefMaxLen, lpdwEntriesRead, lpdwTotalEntries, lpdwResumeHandle)
# hMprConfig : HANDLE -> "void*"
# dwLevel : DWORD -> "dword"
# lplpBuffer : BYTE** out -> "void*"
# dwPrefMaxLen : DWORD -> "dword"
# lpdwEntriesRead : DWORD* out -> "void*"
# lpdwTotalEntries : DWORD* out -> "void*"
# lpdwResumeHandle : DWORD* optional, in/out -> "void*"
# なでしこ1は32bit・ANSI(Shift_JIS)。文字列=char*(ANSI)、ポインタ/ハンドル=void*(4byte)。