MLGetUTF16String (C 関数)
MLGetUTF16StringはWSGetUTF16Stringに置き換えられた.
int MLGetUTF16String(MLINK link,const unsigned short **s,int *n,int *c)
link で指定されたMathLink接続からUTF-16の文字列を得て,その文字列を s に,文字列の長さを n に,そして文字数を c に保持しておく.
詳細
- MLGetUTF16String()は文字列にメモリを割り当てる.このメモリを解放するためにはMLReleaseUTF16String()を呼び出さなくてはならない.MLGetUTF16String()が不成功で関数の返す値がエラーを示す場合には,s のコンテンツについてMLReleaseUTF16String()を呼び出してはならない.
- MLGetUTF16String()は不変のデータを返す.
- MLGetUTF16String()はすべての文字を直接UTF-16 Unicodeのコード化形式で保持する.
- MLGetUTF16String()で返された文字列 s は,バイトオーダーマークで始まる.
- 文字列の長さ n には,バイトオーダーマークが含まれる.
- MLGetUTF16String()はエラーがあると0を返し,関数が成功すると0以外の値を返す.
- MLError()を使うと,MLGetUTF16String()が不成功の場合にエラーコードを引き出すことができる.
- MLGetUTF16String()は,MathLinkヘッダファイルmathlink.hの中で宣言される.
例題
例 (1)
#include "mathlink.h"
/* read a UTF-16 encoded string from a link */
void f(MLINK lp)
{
const unsigned short *string;
int length;
int characters;
if(! MLGetUTF16String(lp, &string, &length, &characters))
{
/* unable to read the UTF-16 string from lp */
return;
}
/* ... */
MLReleaseUTF16String(lp, string, length);
}