Win32 API 日本語リファレンス
ホームGlobalization › ucnv_fromUnicode

ucnv_fromUnicode

関数
Unicodeからバイト列へストリーム変換する。
DLLicuuc.dll呼出規約cdecl

シグネチャ

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

void ucnv_fromUnicode(
    UConverter* converter,
    CHAR** target,
    LPCSTR targetLimit,
    const WORD** source,
    const WORD* sourceLimit,
    INT* offsets,
    CHAR flush,
    UErrorCode* err
);

パラメーター

名前方向
converterUConverter*inout
targetCHAR**inout
targetLimitLPCSTRin
sourceWORD**in
sourceLimitWORD*in
offsetsINT*inout
flushCHARin
errUErrorCode*inout

戻り値の型: void

各言語での呼び出し定義

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

void ucnv_fromUnicode(
    UConverter* converter,
    CHAR** target,
    LPCSTR targetLimit,
    const WORD** source,
    const WORD* sourceLimit,
    INT* offsets,
    CHAR flush,
    UErrorCode* err
);
[DllImport("icuuc.dll", ExactSpelling = true, CallingConvention = CallingConvention.Cdecl)]
static extern void ucnv_fromUnicode(
    ref IntPtr converter,   // UConverter* in/out
    IntPtr target,   // CHAR** in/out
    [MarshalAs(UnmanagedType.LPStr)] string targetLimit,   // LPCSTR
    IntPtr source,   // WORD**
    ref ushort sourceLimit,   // WORD*
    ref int offsets,   // INT* in/out
    sbyte flush,   // CHAR
    ref int err   // UErrorCode* in/out
);
<DllImport("icuuc.dll", ExactSpelling:=True, CallingConvention:=CallingConvention.Cdecl)>
Public Shared Sub ucnv_fromUnicode(
    ByRef converter As IntPtr,   ' UConverter* in/out
    target As IntPtr,   ' CHAR** in/out
    <MarshalAs(UnmanagedType.LPStr)> targetLimit As String,   ' LPCSTR
    source As IntPtr,   ' WORD**
    ByRef sourceLimit As UShort,   ' WORD*
    ByRef offsets As Integer,   ' INT* in/out
    flush As SByte,   ' CHAR
    ByRef err As Integer   ' UErrorCode* in/out
)
End Sub
' converter : UConverter* in/out
' target : CHAR** in/out
' targetLimit : LPCSTR
' source : WORD**
' sourceLimit : WORD*
' offsets : INT* in/out
' flush : CHAR
' err : UErrorCode* in/out
Declare PtrSafe Sub ucnv_fromUnicode Lib "icuuc" ( _
    ByRef converter As LongPtr, _
    ByVal target As LongPtr, _
    ByVal targetLimit As String, _
    ByVal source As LongPtr, _
    ByRef sourceLimit As Integer, _
    ByRef offsets As Long, _
    ByVal flush As Byte, _
    ByRef err As Long)
' VBA7前提(PtrSafe)。32bit Office では LongPtr→Long。Integer=16bit / Long=32bit / LongLong=64bit。
import ctypes
from ctypes import wintypes

ucnv_fromUnicode = ctypes.cdll.icuuc.ucnv_fromUnicode
ucnv_fromUnicode.restype = None
ucnv_fromUnicode.argtypes = [
    ctypes.c_void_p,  # converter : UConverter* in/out
    ctypes.c_void_p,  # target : CHAR** in/out
    wintypes.LPCSTR,  # targetLimit : LPCSTR
    ctypes.c_void_p,  # source : WORD**
    ctypes.POINTER(ctypes.c_ushort),  # sourceLimit : WORD*
    ctypes.POINTER(ctypes.c_int),  # offsets : INT* in/out
    ctypes.c_byte,  # flush : CHAR
    ctypes.c_void_p,  # err : UErrorCode* in/out
]
require 'fiddle'
require 'fiddle/import'

lib = Fiddle.dlopen('icuuc.dll')
ucnv_fromUnicode = Fiddle::Function.new(
  lib['ucnv_fromUnicode'],
  [
    Fiddle::TYPE_VOIDP,  # converter : UConverter* in/out
    Fiddle::TYPE_VOIDP,  # target : CHAR** in/out
    Fiddle::TYPE_VOIDP,  # targetLimit : LPCSTR
    Fiddle::TYPE_VOIDP,  # source : WORD**
    Fiddle::TYPE_VOIDP,  # sourceLimit : WORD*
    Fiddle::TYPE_VOIDP,  # offsets : INT* in/out
    Fiddle::TYPE_CHAR,  # flush : CHAR
    Fiddle::TYPE_VOIDP,  # err : UErrorCode* in/out
  ],
  Fiddle::TYPE_VOID, Fiddle::Function::CDECL)
#[link(name = "icuuc")]
extern "C" {
    fn ucnv_fromUnicode(
        converter: *mut isize,  // UConverter* in/out
        target: *mut *mut i8,  // CHAR** in/out
        targetLimit: *const u8,  // LPCSTR
        source: *const *const u16,  // WORD**
        sourceLimit: *const u16,  // WORD*
        offsets: *mut i32,  // INT* in/out
        flush: i8,  // CHAR
        err: *mut i32  // UErrorCode* in/out
    );
}
// crates: windows-sys provides ready-made bindings for this API.
$sig = @"
[DllImport("icuuc.dll", CallingConvention = CallingConvention.Cdecl)]
public static extern void ucnv_fromUnicode(ref IntPtr converter, IntPtr target, [MarshalAs(UnmanagedType.LPStr)] string targetLimit, IntPtr source, ref ushort sourceLimit, ref int offsets, sbyte flush, ref int err);
"@
$api = Add-Type -MemberDefinition $sig -Name 'icuuc_ucnv_fromUnicode' -Namespace Win32 -PassThru
# $api::ucnv_fromUnicode(converter, target, targetLimit, source, sourceLimit, offsets, flush, err)
#uselib "icuuc.dll"
#func global ucnv_fromUnicode "ucnv_fromUnicode" sptr, sptr, sptr, sptr, sptr, sptr, sptr, sptr
; ucnv_fromUnicode converter, varptr(target), targetLimit, varptr(source), varptr(sourceLimit), varptr(offsets), flush, err
; converter : UConverter* in/out -> "sptr"
; target : CHAR** in/out -> "sptr"
; targetLimit : LPCSTR -> "sptr"
; source : WORD** -> "sptr"
; sourceLimit : WORD* -> "sptr"
; offsets : INT* in/out -> "sptr"
; flush : CHAR -> "sptr"
; err : UErrorCode* in/out -> "sptr"
出力引数:
#uselib "icuuc.dll"
#func global ucnv_fromUnicode "ucnv_fromUnicode" int, var, str, var, var, var, int, int
; ucnv_fromUnicode converter, target, targetLimit, source, sourceLimit, offsets, flush, err
; converter : UConverter* in/out -> "int"
; target : CHAR** in/out -> "var"
; targetLimit : LPCSTR -> "str"
; source : WORD** -> "var"
; sourceLimit : WORD* -> "var"
; offsets : INT* in/out -> "var"
; flush : CHAR -> "int"
; err : UErrorCode* in/out -> "int"
; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。
出力引数:
; void ucnv_fromUnicode(UConverter* converter, CHAR** target, LPCSTR targetLimit, WORD** source, WORD* sourceLimit, INT* offsets, CHAR flush, UErrorCode* err)
#uselib "icuuc.dll"
#func global ucnv_fromUnicode "ucnv_fromUnicode" int, var, str, var, var, var, int, int
; ucnv_fromUnicode converter, target, targetLimit, source, sourceLimit, offsets, flush, err
; converter : UConverter* in/out -> "int"
; target : CHAR** in/out -> "var"
; targetLimit : LPCSTR -> "str"
; source : WORD** -> "var"
; sourceLimit : WORD* -> "var"
; offsets : INT* in/out -> "var"
; flush : CHAR -> "int"
; err : UErrorCode* in/out -> "int"
; ※出力/バッファ引数は var 方式(変数を直接渡す)。varptr 方式にも切替可。
import (
	"golang.org/x/sys/windows"
	"unsafe"
)

var (
	icuuc = windows.NewLazySystemDLL("icuuc.dll")
	procucnv_fromUnicode = icuuc.NewProc("ucnv_fromUnicode")
)

// converter (UConverter* in/out), target (CHAR** in/out), targetLimit (LPCSTR), source (WORD**), sourceLimit (WORD*), offsets (INT* in/out), flush (CHAR), err (UErrorCode* in/out)
r1, _, err := procucnv_fromUnicode.Call(
	uintptr(converter),
	uintptr(target),
	uintptr(unsafe.Pointer(windows.BytePtrFromString(targetLimit))),
	uintptr(source),
	uintptr(sourceLimit),
	uintptr(offsets),
	uintptr(flush),
	uintptr(err),
)
_ = err  // syscall.Errno (valid when the call sets last-error)
_ = r1   // void
procedure ucnv_fromUnicode(
  converter: Pointer;   // UConverter* in/out
  target: Pointer;   // CHAR** in/out
  targetLimit: PAnsiChar;   // LPCSTR
  source: Pointer;   // WORD**
  sourceLimit: Pointer;   // WORD*
  offsets: Pointer;   // INT* in/out
  flush: Shortint;   // CHAR
  err: Pointer   // UErrorCode* in/out
); cdecl;
  external 'icuuc.dll' name 'ucnv_fromUnicode';
result := DllCall("icuuc\ucnv_fromUnicode"
    , "Ptr", converter   ; UConverter* in/out
    , "Ptr", target   ; CHAR** in/out
    , "AStr", targetLimit   ; LPCSTR
    , "Ptr", source   ; WORD**
    , "Ptr", sourceLimit   ; WORD*
    , "Ptr", offsets   ; INT* in/out
    , "Char", flush   ; CHAR
    , "Ptr", err   ; UErrorCode* in/out
    , "Cdecl Int")   ; return: void
●ucnv_fromUnicode(converter, target, targetLimit, source, sourceLimit, offsets, flush, err) = DLL("icuuc.dll", "int ucnv_fromUnicode(void*, void*, char*, void*, void*, void*, char, void*)")
# 呼び出し: ucnv_fromUnicode(converter, target, targetLimit, source, sourceLimit, offsets, flush, err)
# converter : UConverter* in/out -> "void*"
# target : CHAR** in/out -> "void*"
# targetLimit : LPCSTR -> "char*"
# source : WORD** -> "void*"
# sourceLimit : WORD* -> "void*"
# offsets : INT* in/out -> "void*"
# flush : CHAR -> "char"
# err : UErrorCode* in/out -> "void*"
# なでしこ1は32bit・ANSI(Shift_JIS)。文字列=char*(ANSI)、ポインタ/ハンドル=void*(4byte)。
# ※cdecl関数。DLL()宣言はstdcall前提。cdeclは EXEC_PTR(`cdecl`,…) を使用。