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

TcQueryInterface

関数
トラフィック制御インターフェイスのパラメータを問い合わせる。
DLLTRAFFIC.dll呼出規約winapi対応OSWindows 2000 以降

シグネチャ

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

DWORD TcQueryInterface(
    HANDLE IfcHandle,
    GUID* pGuidParam,
    BOOLEAN NotifyChange,
    DWORD* pBufferSize,
    void* Buffer
);

パラメーター

名前方向
IfcHandleHANDLEin
pGuidParamGUID*in
NotifyChangeBOOLEANin
pBufferSizeDWORD*inout
Buffervoid*out

戻り値の型: DWORD

各言語での呼び出し定義

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

DWORD TcQueryInterface(
    HANDLE IfcHandle,
    GUID* pGuidParam,
    BOOLEAN NotifyChange,
    DWORD* pBufferSize,
    void* Buffer
);
[DllImport("TRAFFIC.dll", ExactSpelling = true)]
static extern uint TcQueryInterface(
    IntPtr IfcHandle,   // HANDLE
    ref Guid pGuidParam,   // GUID*
    [MarshalAs(UnmanagedType.U1)] bool NotifyChange,   // BOOLEAN
    ref uint pBufferSize,   // DWORD* in/out
    IntPtr Buffer   // void* out
);
<DllImport("TRAFFIC.dll", ExactSpelling:=True)>
Public Shared Function TcQueryInterface(
    IfcHandle As IntPtr,   ' HANDLE
    ByRef pGuidParam As Guid,   ' GUID*
    <MarshalAs(UnmanagedType.U1)> NotifyChange As Boolean,   ' BOOLEAN
    ByRef pBufferSize As UInteger,   ' DWORD* in/out
    Buffer As IntPtr   ' void* out
) As UInteger
End Function
' IfcHandle : HANDLE
' pGuidParam : GUID*
' NotifyChange : BOOLEAN
' pBufferSize : DWORD* in/out
' Buffer : void* out
Declare PtrSafe Function TcQueryInterface Lib "traffic" ( _
    ByVal IfcHandle As LongPtr, _
    ByVal pGuidParam As LongPtr, _
    ByVal NotifyChange As Byte, _
    ByRef pBufferSize As Long, _
    ByVal Buffer As LongPtr) As Long
' VBA7前提(PtrSafe)。32bit Office では LongPtr→Long。Integer=16bit / Long=32bit / LongLong=64bit。
import ctypes
from ctypes import wintypes

TcQueryInterface = ctypes.windll.traffic.TcQueryInterface
TcQueryInterface.restype = wintypes.DWORD
TcQueryInterface.argtypes = [
    wintypes.HANDLE,  # IfcHandle : HANDLE
    ctypes.c_void_p,  # pGuidParam : GUID*
    ctypes.c_byte,  # NotifyChange : BOOLEAN
    ctypes.POINTER(wintypes.DWORD),  # pBufferSize : DWORD* in/out
    ctypes.POINTER(None),  # Buffer : void* out
]
require 'fiddle'
require 'fiddle/import'

lib = Fiddle.dlopen('TRAFFIC.dll')
TcQueryInterface = Fiddle::Function.new(
  lib['TcQueryInterface'],
  [
    Fiddle::TYPE_VOIDP,  # IfcHandle : HANDLE
    Fiddle::TYPE_VOIDP,  # pGuidParam : GUID*
    Fiddle::TYPE_CHAR,  # NotifyChange : BOOLEAN
    Fiddle::TYPE_VOIDP,  # pBufferSize : DWORD* in/out
    Fiddle::TYPE_VOIDP,  # Buffer : void* out
  ],
  -Fiddle::TYPE_INT)
#[link(name = "traffic")]
extern "system" {
    fn TcQueryInterface(
        IfcHandle: *mut core::ffi::c_void,  // HANDLE
        pGuidParam: *mut GUID,  // GUID*
        NotifyChange: u8,  // BOOLEAN
        pBufferSize: *mut u32,  // DWORD* in/out
        Buffer: *mut ()  // void* out
    ) -> u32;
}
// crates: windows-sys provides ready-made bindings for this API.
$sig = @"
[DllImport("TRAFFIC.dll")]
public static extern uint TcQueryInterface(IntPtr IfcHandle, ref Guid pGuidParam, [MarshalAs(UnmanagedType.U1)] bool NotifyChange, ref uint pBufferSize, IntPtr Buffer);
"@
$api = Add-Type -MemberDefinition $sig -Name 'TRAFFIC_TcQueryInterface' -Namespace Win32 -PassThru
# $api::TcQueryInterface(IfcHandle, pGuidParam, NotifyChange, pBufferSize, Buffer)
#uselib "TRAFFIC.dll"
#func global TcQueryInterface "TcQueryInterface" sptr, sptr, sptr, sptr, sptr
; TcQueryInterface IfcHandle, varptr(pGuidParam), NotifyChange, varptr(pBufferSize), Buffer   ; 戻り値は stat
; IfcHandle : HANDLE -> "sptr"
; pGuidParam : GUID* -> "sptr"
; NotifyChange : BOOLEAN -> "sptr"
; pBufferSize : DWORD* in/out -> "sptr"
; Buffer : void* out -> "sptr"
; ※HSP3.7は #func のため戻り値はシステム変数 stat に格納されます。
出力引数:
#uselib "TRAFFIC.dll"
#cfunc global TcQueryInterface "TcQueryInterface" sptr, var, int, var, sptr
; res = TcQueryInterface(IfcHandle, pGuidParam, NotifyChange, pBufferSize, Buffer)
; IfcHandle : HANDLE -> "sptr"
; pGuidParam : GUID* -> "var"
; NotifyChange : BOOLEAN -> "int"
; pBufferSize : DWORD* in/out -> "var"
; Buffer : void* out -> "sptr"
; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。
出力引数:
; DWORD TcQueryInterface(HANDLE IfcHandle, GUID* pGuidParam, BOOLEAN NotifyChange, DWORD* pBufferSize, void* Buffer)
#uselib "TRAFFIC.dll"
#cfunc global TcQueryInterface "TcQueryInterface" intptr, var, int, var, intptr
; res = TcQueryInterface(IfcHandle, pGuidParam, NotifyChange, pBufferSize, Buffer)
; IfcHandle : HANDLE -> "intptr"
; pGuidParam : GUID* -> "var"
; NotifyChange : BOOLEAN -> "int"
; pBufferSize : DWORD* in/out -> "var"
; Buffer : void* out -> "intptr"
; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。
import (
	"golang.org/x/sys/windows"
	"unsafe"
)

var (
	traffic = windows.NewLazySystemDLL("TRAFFIC.dll")
	procTcQueryInterface = traffic.NewProc("TcQueryInterface")
)

// IfcHandle (HANDLE), pGuidParam (GUID*), NotifyChange (BOOLEAN), pBufferSize (DWORD* in/out), Buffer (void* out)
r1, _, err := procTcQueryInterface.Call(
	uintptr(IfcHandle),
	uintptr(pGuidParam),
	uintptr(NotifyChange),
	uintptr(pBufferSize),
	uintptr(Buffer),
)
_ = err  // syscall.Errno (valid when the call sets last-error)
_ = r1   // DWORD
function TcQueryInterface(
  IfcHandle: THandle;   // HANDLE
  pGuidParam: PGUID;   // GUID*
  NotifyChange: ByteBool;   // BOOLEAN
  pBufferSize: Pointer;   // DWORD* in/out
  Buffer: Pointer   // void* out
): DWORD; stdcall;
  external 'TRAFFIC.dll' name 'TcQueryInterface';
result := DllCall("TRAFFIC\TcQueryInterface"
    , "Ptr", IfcHandle   ; HANDLE
    , "Ptr", pGuidParam   ; GUID*
    , "Char", NotifyChange   ; BOOLEAN
    , "Ptr", pBufferSize   ; DWORD* in/out
    , "Ptr", Buffer   ; void* out
    , "UInt")   ; return: DWORD
●TcQueryInterface(IfcHandle, pGuidParam, NotifyChange, pBufferSize, Buffer) = DLL("TRAFFIC.dll", "dword TcQueryInterface(void*, void*, byte, void*, void*)")
# 呼び出し: TcQueryInterface(IfcHandle, pGuidParam, NotifyChange, pBufferSize, Buffer)
# IfcHandle : HANDLE -> "void*"
# pGuidParam : GUID* -> "void*"
# NotifyChange : BOOLEAN -> "byte"
# pBufferSize : DWORD* in/out -> "void*"
# Buffer : void* out -> "void*"
# なでしこ1は32bit・ANSI(Shift_JIS)。文字列=char*(ANSI)、ポインタ/ハンドル=void*(4byte)。