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