MLGetUnicodeString (C 関数)
MLGetUnicodeStringはWSGetUnicodeStringに置き換えられた.
int MLGetUnicodeString(MLINK link,unsigned short **s,long *n)
link で指定されたMathLink接続から文字列を得て,その文字列を s に16ビットのUnicode文字列として保持しておく.
詳細

- MLGetUnicodeString()は文字列にメモリを割り当てる.このメモリを解放するためにはMLDisownUnicodeString()を呼び出さなくてはならない.MLGetUnicodeString()が不成功で関数の返す値がエラーを示している場合には,s のコンテンツについてMLDisownUnicodeString()を呼び出してはならない.
は不変のデータを返す.
- MLGetUnicodeString()はすべての文字を直接16ビットのUCS-2形式で保持する.
- ASCII文字は高次のヌルバイトが付加されて保持される.
- MLGetUnicodeString() はエラーがあると0を返し,関数が成功すると0以外の値を返す.
- MLError()を使うと,MLGetUnicodeString()が不成功の場合にエラーコードを引き出すことができる.
- MLGetUnicodeString()はMLGetUCS2String()に等しい.
例題
例 (1)
#include "mathlink.h"
/* read a UCS-2 encoded string from a link */
void f(MLINK lp)
{
const unsigned short *string;
long length;
if(! MLGetUnicodeString(lp, &string, &length))
{
/* unable to read the UCS-2 string */
return;
}
/* ... */
MLDisownUnicodeString(lp, string, length);
}