MLGetFunction (C 関数)
MLGetFunctionはWSGetFunctionに置き換えられた.
int MLGetFunction(MLINK link,const char **s,int *n)
link で指定されたMathLink接続から記号を頭部として持つ関数を得て,その記号名を s に,そして関数の引数の数を n に保持しておく.
詳細
- MLGetFunction()は関数の頭部の名前に対応する文字列にメモリを割り当てる. このメモリを開放するためには,MLReleaseSymbol()を呼び出さなければならない.MLGetFunction()が不成功で関数の返す値がエラーを示している場合には,s の内容についてMLReleaseSymbol()を呼び出してはならない.
- 外部プログラムで文字列s を変更してはならない.
- は,MLGetNext(link),MLGetArgCount(link,&n),MLGetSymbol(link,&s)と同じ働きをする.
- MLGetFunction()はエラーがあると0を返し,関数が成功すると0以外の値を返す.
- MLError()を使うと,MLGetFunction()が不成功の場合にエラーコードを引き出すことができる.
- MLGetFunction()は,MathLinkヘッダファイルmathlink.hの中で宣言される.
例題
例 (1)
#include "mathlink.h"
/* read a Mathematica function from a link */
void f(MLINK lp)
{
const char *f;
int n;
if(! MLGetFunction(lp, &f, &n))
{
/* unable to read the function from lp */
return;
}
/* ... */
MLReleaseSymbol(lp, f);
}