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

TcQueryFlowW

関数
指定フローのトラフィック制御パラメータを問い合わせる(Unicode版)。
DLLTRAFFIC.dll文字セットUnicode (-W)呼出規約winapi対応OSWindows 2000 以降

シグネチャ

// TRAFFIC.dll  (Unicode / -W)
#include <windows.h>

DWORD TcQueryFlowW(
    LPWSTR pFlowName,
    GUID* pGuidParam,
    DWORD* pBufferSize,
    void* Buffer
);

パラメーター

名前方向
pFlowNameLPWSTRin
pGuidParamGUID*in
pBufferSizeDWORD*inout
Buffervoid*out

戻り値の型: DWORD

各言語での呼び出し定義

// TRAFFIC.dll  (Unicode / -W)
#include <windows.h>

DWORD TcQueryFlowW(
    LPWSTR pFlowName,
    GUID* pGuidParam,
    DWORD* pBufferSize,
    void* Buffer
);
[DllImport("TRAFFIC.dll", CharSet = CharSet.Unicode, ExactSpelling = true)]
static extern uint TcQueryFlowW(
    [MarshalAs(UnmanagedType.LPWStr)] string pFlowName,   // LPWSTR
    ref Guid pGuidParam,   // GUID*
    ref uint pBufferSize,   // DWORD* in/out
    IntPtr Buffer   // void* out
);
<DllImport("TRAFFIC.dll", CharSet:=CharSet.Unicode, ExactSpelling:=True)>
Public Shared Function TcQueryFlowW(
    <MarshalAs(UnmanagedType.LPWStr)> pFlowName As String,   ' LPWSTR
    ByRef pGuidParam As Guid,   ' GUID*
    ByRef pBufferSize As UInteger,   ' DWORD* in/out
    Buffer As IntPtr   ' void* out
) As UInteger
End Function
' pFlowName : LPWSTR
' pGuidParam : GUID*
' pBufferSize : DWORD* in/out
' Buffer : void* out
Declare PtrSafe Function TcQueryFlowW Lib "traffic" ( _
    ByVal pFlowName As LongPtr, _
    ByVal pGuidParam As LongPtr, _
    ByRef pBufferSize As Long, _
    ByVal Buffer As LongPtr) As Long
' Unicode(W): 文字列は ByVal As LongPtr とし StrPtr(unicodeStr) を渡す
' VBA7前提(PtrSafe)。32bit Office では LongPtr→Long。Integer=16bit / Long=32bit / LongLong=64bit。
import ctypes
from ctypes import wintypes

TcQueryFlowW = ctypes.windll.traffic.TcQueryFlowW
TcQueryFlowW.restype = wintypes.DWORD
TcQueryFlowW.argtypes = [
    wintypes.LPCWSTR,  # pFlowName : LPWSTR
    ctypes.c_void_p,  # pGuidParam : GUID*
    ctypes.POINTER(wintypes.DWORD),  # pBufferSize : DWORD* in/out
    ctypes.POINTER(None),  # Buffer : void* out
]
require 'fiddle'
require 'fiddle/import'

lib = Fiddle.dlopen('TRAFFIC.dll')
TcQueryFlowW = Fiddle::Function.new(
  lib['TcQueryFlowW'],
  [
    Fiddle::TYPE_VOIDP,  # pFlowName : LPWSTR
    Fiddle::TYPE_VOIDP,  # pGuidParam : GUID*
    Fiddle::TYPE_VOIDP,  # pBufferSize : DWORD* in/out
    Fiddle::TYPE_VOIDP,  # Buffer : void* out
  ],
  -Fiddle::TYPE_INT)
# Wide strings: pass str.encode("UTF-16LE") + "\x00\x00"
#[link(name = "traffic")]
extern "system" {
    fn TcQueryFlowW(
        pFlowName: *mut u16,  // LPWSTR
        pGuidParam: *mut GUID,  // GUID*
        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", CharSet = CharSet.Unicode)]
public static extern uint TcQueryFlowW([MarshalAs(UnmanagedType.LPWStr)] string pFlowName, ref Guid pGuidParam, ref uint pBufferSize, IntPtr Buffer);
"@
$api = Add-Type -MemberDefinition $sig -Name 'TRAFFIC_TcQueryFlowW' -Namespace Win32 -PassThru
# $api::TcQueryFlowW(pFlowName, pGuidParam, pBufferSize, Buffer)
#uselib "TRAFFIC.dll"
#func global TcQueryFlowW "TcQueryFlowW" wptr, wptr, wptr, wptr
; TcQueryFlowW pFlowName, varptr(pGuidParam), varptr(pBufferSize), Buffer   ; 戻り値は stat
; pFlowName : LPWSTR -> "wptr"
; pGuidParam : GUID* -> "wptr"
; pBufferSize : DWORD* in/out -> "wptr"
; Buffer : void* out -> "wptr"
; ※HSP3.7は #func のため戻り値はシステム変数 stat に格納されます。
出力引数:
#uselib "TRAFFIC.dll"
#cfunc global TcQueryFlowW "TcQueryFlowW" wstr, var, var, sptr
; res = TcQueryFlowW(pFlowName, pGuidParam, pBufferSize, Buffer)
; pFlowName : LPWSTR -> "wstr"
; pGuidParam : GUID* -> "var"
; pBufferSize : DWORD* in/out -> "var"
; Buffer : void* out -> "sptr"
; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。
出力引数:
; DWORD TcQueryFlowW(LPWSTR pFlowName, GUID* pGuidParam, DWORD* pBufferSize, void* Buffer)
#uselib "TRAFFIC.dll"
#cfunc global TcQueryFlowW "TcQueryFlowW" wstr, var, var, intptr
; res = TcQueryFlowW(pFlowName, pGuidParam, pBufferSize, Buffer)
; pFlowName : LPWSTR -> "wstr"
; pGuidParam : GUID* -> "var"
; pBufferSize : DWORD* in/out -> "var"
; Buffer : void* out -> "intptr"
; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。
import (
	"golang.org/x/sys/windows"
	"unsafe"
)

var (
	traffic = windows.NewLazySystemDLL("TRAFFIC.dll")
	procTcQueryFlowW = traffic.NewProc("TcQueryFlowW")
)

// pFlowName (LPWSTR), pGuidParam (GUID*), pBufferSize (DWORD* in/out), Buffer (void* out)
r1, _, err := procTcQueryFlowW.Call(
	uintptr(unsafe.Pointer(windows.StringToUTF16Ptr(pFlowName))),
	uintptr(pGuidParam),
	uintptr(pBufferSize),
	uintptr(Buffer),
)
_ = err  // syscall.Errno (valid when the call sets last-error)
_ = r1   // DWORD
function TcQueryFlowW(
  pFlowName: PWideChar;   // LPWSTR
  pGuidParam: PGUID;   // GUID*
  pBufferSize: Pointer;   // DWORD* in/out
  Buffer: Pointer   // void* out
): DWORD; stdcall;
  external 'TRAFFIC.dll' name 'TcQueryFlowW';
result := DllCall("TRAFFIC\TcQueryFlowW"
    , "WStr", pFlowName   ; LPWSTR
    , "Ptr", pGuidParam   ; GUID*
    , "Ptr", pBufferSize   ; DWORD* in/out
    , "Ptr", Buffer   ; void* out
    , "UInt")   ; return: DWORD
●TcQueryFlowW(pFlowName, pGuidParam, pBufferSize, Buffer) = DLL("TRAFFIC.dll", "dword TcQueryFlowW(char*, void*, void*, void*)")
# 呼び出し: TcQueryFlowW(pFlowName, pGuidParam, pBufferSize, Buffer)
# pFlowName : LPWSTR -> "char*"
# pGuidParam : GUID* -> "void*"
# pBufferSize : DWORD* in/out -> "void*"
# Buffer : void* out -> "void*"
# なでしこ1は32bit・ANSI(Shift_JIS)。文字列=char*(ANSI)、ポインタ/ハンドル=void*(4byte)。
# ※-W(Unicode)関数。なでしこ1はANSIのため -A 版の利用を推奨。