MLGetUTF32String (C 関数)

MLGetUTF32StringWSGetUTF32Stringに置き換えられた.

int MLGetUTF32String(MLINK link,const unsigned int **s,int *len)

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

詳細

  • MLGetUTF32String()は文字列にメモリを割り当てる.このメモリを解放するためにはMLReleaseUTF32String()を呼び出さなくてはならない.MLGetUTF32String()が不成功で関数の返す値がエラーを示す場合には,s のコンテンツについてMLReleaseUTF32String()を呼び出してはならない.
  • MLGetUTF32String()は不変のデータを返す.
  • MLGetUTF32String()はすべての文字を直接UTF-32のコード化形式で保持する.
  • MLGetUTF32String()で返された文字列 s は,バイトオーダーマークで始まる.
  • 文字列の長さ len には,バイトオーダーマークが含まれる.
  • MLGetUTF32String()はエラーがあると0を返し,関数が成功すると0以外の値を返す.
  • MLError()を使うと,MLGetUTF32String()が不成功の場合にエラーコードを引き出すことができる.
  • MLGetUTF32String()は,MathLinkヘッダファイルmathlink.hの中で宣言される.

例題

  (1)

#include "mathlink.h"

/* read a UTF-32 encoded string from a link */

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

    if(! MLGetUTF32String(lp, &string, &len))
        {
            /* unable to read the UTF-32 string from lp */
            return;
        }

    /* ... */

    MLReleaseUTF32String(lp, string, len);
}