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

MprAdminInterfaceEnum

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

シグネチャ

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

DWORD MprAdminInterfaceEnum(
    INT_PTR hMprServer,
    DWORD dwLevel,
    BYTE** lplpbBuffer,
    DWORD dwPrefMaxLen,
    DWORD* lpdwEntriesRead,
    DWORD* lpdwTotalEntries,
    DWORD* lpdwResumeHandle   // optional
);

パラメーター

名前方向
hMprServerINT_PTRin
dwLevelDWORDin
lplpbBufferBYTE**out
dwPrefMaxLenDWORDin
lpdwEntriesReadDWORD*out
lpdwTotalEntriesDWORD*out
lpdwResumeHandleDWORD*inoptional

戻り値の型: DWORD

各言語での呼び出し定義

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

DWORD MprAdminInterfaceEnum(
    INT_PTR hMprServer,
    DWORD dwLevel,
    BYTE** lplpbBuffer,
    DWORD dwPrefMaxLen,
    DWORD* lpdwEntriesRead,
    DWORD* lpdwTotalEntries,
    DWORD* lpdwResumeHandle   // optional
);
[DllImport("MPRAPI.dll", ExactSpelling = true)]
static extern uint MprAdminInterfaceEnum(
    IntPtr hMprServer,   // INT_PTR
    uint dwLevel,   // DWORD
    IntPtr lplpbBuffer,   // BYTE** out
    uint dwPrefMaxLen,   // DWORD
    out uint lpdwEntriesRead,   // DWORD* out
    out uint lpdwTotalEntries,   // DWORD* out
    IntPtr lpdwResumeHandle   // DWORD* optional
);
<DllImport("MPRAPI.dll", ExactSpelling:=True)>
Public Shared Function MprAdminInterfaceEnum(
    hMprServer As IntPtr,   ' INT_PTR
    dwLevel As UInteger,   ' DWORD
    lplpbBuffer 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
) As UInteger
End Function
' hMprServer : INT_PTR
' dwLevel : DWORD
' lplpbBuffer : BYTE** out
' dwPrefMaxLen : DWORD
' lpdwEntriesRead : DWORD* out
' lpdwTotalEntries : DWORD* out
' lpdwResumeHandle : DWORD* optional
Declare PtrSafe Function MprAdminInterfaceEnum Lib "mprapi" ( _
    ByVal hMprServer As LongPtr, _
    ByVal dwLevel As Long, _
    ByVal lplpbBuffer 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

MprAdminInterfaceEnum = ctypes.windll.mprapi.MprAdminInterfaceEnum
MprAdminInterfaceEnum.restype = wintypes.DWORD
MprAdminInterfaceEnum.argtypes = [
    ctypes.c_ssize_t,  # hMprServer : INT_PTR
    wintypes.DWORD,  # dwLevel : DWORD
    ctypes.c_void_p,  # lplpbBuffer : 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
]
require 'fiddle'
require 'fiddle/import'

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

var (
	mprapi = windows.NewLazySystemDLL("MPRAPI.dll")
	procMprAdminInterfaceEnum = mprapi.NewProc("MprAdminInterfaceEnum")
)

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