MLGetIntegerArray (C 関数)
MLGetIntegerArrayはWSGetIntegerArrayに置き換えられた.
int MLGetIntegerArray(MLINK link,int **a,long **dims,char ***heads,long *d)
link で指定されたMathLink接続から整数の配列を得て,配列を a に,その次元を dims に,そしてその深さを d に保持しておく.
詳細

- 配列 a は
と宣言されたC言語の配列のようにメモリにレイアウトされる.
- heads は,配列の各レベルに頭部として現れる記号名に対応する文字列のリストを返す.
- MLGetIntegerArray()は,MLDisownIntegerArray()を呼び出して解放しなければならないメモリを割り当てる.MLGetIntegerArray()が不成功で関数の返す値がエラーを示す場合には,a のコンテンツについてMLDisownIntegerArray()を呼び出してはならない.
- MLGetIntegerArray()が生成した配列を外部プログラムで変更してはならない.
- MLGetIntegerArray()はエラーがあると0を返し,関数が成功すると0以外の値を返す.
- MLError()を使うと,MLGetIntegerArray()が不成功の場合にエラーコードを引き出すことができる.
- MLGetIntegerArray()は,MLGetInteger32Array()と等価である.
例題
例 (1)
#include "mathlink.h"
/* read an array of integers from a link */
void f(MLINK lp)
{
int *data;
long *dims;
char **heads;
long d;
if(! MLGetIntegerArray(lp, &data, &dims, &heads, &d))
{
/* unable to read the integer array */
return;
}
/* ... */
MLDisownIntegerArray(lp, data, dims, heads, d);
}