WSGetUTF8String (C 関数)
int WSGetUTF8String(WSLINK link,const unsigned char **s,int *b,int *c)
link で指定されたWSTP接続からUTF-8の文字列を得て,その文字列を s に,文字列内のバイト数を b に,そして文字列内の文字数を c に保持しておく.
詳細
- WSGetUTF8String()は文字列にメモリを割り当てる.このメモリを解放するためにはWSReleaseUTF8String()を呼び出さなくてはならない.WSGetUTF8String()が不成功で関数の返す値がエラーを示している場合には,s のコンテンツについてWSReleaseUTF8String()を呼び出してはならない.
- WSGetUTF8String()は不変のデータを返す.
- WSGetUTF8String()はすべての文字を直接UTF-8 Unicodeのコード化形式で保持する.
- WSGetUTF8String()はエラーがあると0を返し,関数が成功すると0以外の値を返す.
- WSError()を使うと,WSGetUTF8String()が不成功の場合にエラーコードを引き出すことができる.
- WSGetUTF8String()は,WSTPヘッダファイルwstp.hの中で宣言される.
例題
例 (1)
#include "wstp.h"
/* read a UTF-8 encoded string from a link */
void f(WSLINK lp)
{
const unsigned char *string;
int bytes;
int characters;
if(! WSGetUTF8String(lp, &string, &bytes, &characters))
{
/* unable to read the UTF-8 string from lp */
return;
}
/* use the string */
WSReleaseUTF8String(lp, string, bytes);
}