MLGetUCS2String (C 関数)

MLGetUCS2StringWSGetUCS2Stringに置き換えられた.

int MLGetUCS2String(MLINK link,const unsigned short **s,int *n)

link で指定されたMathLink接続から文字列を得て,その文字列を s にUCS-2の文字列として保持しておく.

詳細

  • MLGetUCS2String()は文字列にメモリを割り当てる.このメモリを解放するためにはMLReleaseUCS2String()を呼び出さなくてはならない.MLGetUCS2String()が不成功で関数の返す値がエラーを示す場合には,s のコンテンツについてMLReleaseUCS2String()を呼び出してはならない.
  • MLGetUCS2String()は不変のデータを返す.
  • はすべての文字を直接16ビットのUCS-2形式で保持する.
  • ASCII文字は高次のヌルバイトが付加されて保持される.
  • MLGetUCS2String()はエラーがあると0を返し,関数が成功すると0以外の値を返す.
  • MLError()を使うと,MLGetUCS2String()が不成功の場合にエラーコードを引き出すことができる.
  • MLGetUCS2String()は,MathLinkヘッダファイルmathlink.hの中で宣言される.

例題

  (1)

#include "mathlink.h"

/* read a UCS-2 encoded string from a link */

void f(MLINK lp)
{
    const unsigned short *string;
    int length;

    if(! MLGetUCS2String(lp, &string, &length))
        {
            /* unable to read the UCS-2 string */
            return;
        }

    /* ... */

    MLReleaseUCS2String(lp, string, length);
}