MLGetUTF8String()

int MLGetUTF8String(MLINK link, const unsigned char **s, int *b, int *c)
link で指定された MathLink 接続からUTF-8の文字列を得て,その文字列を s に,文字列内のバイト数を b に,そして文字列内の文字数を c に保持しておく.

詳細詳細

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

例題例題すべて開くすべて閉じる

例 (1)例 (1)

#include "mathlink.h"

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

void f(MLINK lp)
{
    const unsigned char *string;
    int bytes;
    int characters;

    if(! MLGetUTF8String(lp, &string, &bytes, &characters))
        {
            /* unable to read the UTF-8 string from lp */
            return;
        }

    /* use the string */

    MLReleaseUTF8String(lp, string, bytes);
}
New to Mathematica? Find your learning path »
Have a question? Ask support »