WSGetNumberAsUTF8String (C 関数)
int WSGetNumberAsUTF8String(WSLINK l, const unsigned char **s, int *v, int *c)
l が指定するWSTP接続上の次の数を,長さが v で文字数が c の文字列 s に保存された数の値を表すUTF-8の文字列として読み取る.
詳細
- WSGetNumberAsUTF8String()はメモリを割り当てて,文字列の値を保存する.WSGetNumberAsUTF8String()によって割り当てられたメモリを解放するには,s の内容についてWSReleaseUTF8String()を呼び出す.WSGetNumberAsUTF8String()が失敗した場合には,s の内容についてWSReleaseUTF8String()を呼び出してはならない.
- WSGetNumberAsUTF8String()は,エラーの場合には0を,関数が成功した場合には非零の値を返す.
- WSGetNumberAsUTF8String()は,WSTPヘッダファイルwstp.hの中で宣言される.
例題
例 (1)
#include "wstp.h"
/* A function for reading an integer from a link */
void f(WSLINK l)
{
switch(WSGetType(l))
{
case WSTKINT:
{
int rawType;
rawType = WSGetRawType(l);
if(rawType == WSTK_WSSHORT)
{
short theNumber;
WSGetInteger16(l, &theNumber);
/* ... */
}
else if(rawType == WSTK_WSINT)
{
int theNumber;
WSGetInteger32(l, &theNumber);
/* ... */
}
else
{
const unsigned char *theNumber;
int length, characters;
WSGetNumberAsUTF8String(l, &theNumber, &length, &characters);
/* ... */
WSReleaseUTF8String(l, theNumber, length);
}
}
break;
case WSTKREAL:
/* ... */
}
}