MLYieldFunctionObject (C 関数)

MLYieldFunctionObjectWSYieldFunctionObjectに置き換えられた.

MLINKオブジェクトを引数として,またMLYieldParametersオブジェクトを引数として取り,int型を返して,関数に関数ポインタを表現するMathLinkのタイプである.

詳細

  • MathLink APIの呼出しは,データが読取りに使えるようになるか,あるいは書込みに必要な容量ができるようになるまで,阻止されることがある.その阻止時間中にアプリケーションで他の有用な処理を行う必要がある場合は,そのアプリケーションにリンクのための降伏関数をインストールすれば,MathLinkが自動的に阻止時間中に降伏関数の呼出しを行うようになる.
  • 阻止された読取りや書込みを取り消すためには,降伏関数はゼロ以外の値を返すべきである.
  • MLYieldParametersオブジェクトは現在サポートされていないもので,下位互換性のためだけに維持されている.
  • Windowsでは,MLYieldFunctionObjectはWINAPI呼出し規則を使う.
  • MLYieldFunctionObjectは,MathLinkヘッダファイルmathlink.hの中で宣言される.

例題

  (1)

#include "mathlink.h"

#if UNIX_MATHLINK
#    define CALLING_CONVENTION
#elif WINDOWS_MATHLINK
#    define CALLING_CONVENTION WINAPI
#endif

int CALLING_CONVENTION AppYieldFunction(MLINK lp, MLYieldParameters yp)
{
    /* ... */
    return 0;
}

int main(int argc, char **argv)
{
    MLENV env;
    MLINK link;
    int error;

    env = MLInitialize((MLEnvironmentParameter)0);
    if(env == (MLENV)0)
        { /* unable to initialize MathLink environment */ }

    link = MLOpenArgcArgv(env, argv, argv + argc, &error);
    if(link == (MLINK)0 || error != MLEOK)
        { /* unable to create the link */ }

    if(! MLSetYieldFunction(link, AppYieldFunction))
        { /* unable to set the yield function for link */ }

    /* ... */

    MLClose(link);
    MLDeinitialize(env);
    return 0;
}