Idle Call
You can have FileMaker call your plugin during the standard system idle call. During this time, you can execute call backs to FileMaker, including Script and/or SQL callbacks.
NOTE : Be careful that your idle code doesn't take too much time - it's called frequently and any time it takes reduces the overall performance of FileMaker.
Contents
Step One - Enable Idle Time Flag
Set the 'Want idle time' flag in the plugin Option String to be 'Y' (the third to last flag)
#define IDMA_Plugin_OptionString "IDMA1nnYYnn" // ^--^ || | |---- // No Win32s support // | || |------ // Want idle time // | ||-------- // No old external functions // | |--------- // Has preferences dialog // |-------------- // 'IDMA' plug-in ID
Step Two - FMExternCallProc
This is the key function that FileMaker calls to initialise, shutdown, get name or perform during idle time.
It shouldn't be necessary to edit this function.
void FMX_ENTRYPT FMExternCallProc(FMX_ExternCallPtr pb)
{
// Setup global defined in FMxExtern.h
gFMX_ExternCallPtr = pb;
// Message dispatcher
switch (gFMX_ExternCallPtr->whichCall)
{
case kFMXT_Init:
{
// Msg = Parm1 Parm2 Parm3
// kFMXT_Init FMX_Application value App vers unicode c str* [unused]
gFMX_ExternCallPtr->result = Do_PluginInit(gFMX_ExternCallPtr->extnVersion, gFMX_ExternCallPtr->parm1 );
}
break;
case kFMXT_Idle:
{
Do_PluginIdle(gFMX_ExternCallPtr->parm1);
}
break;
case kFMXT_Shutdown:
{
Do_PluginShutdown();
}
break;
case kFMXT_DoAppPreferences:
{
Do_PluginPrefs();
}
break;
case kFMXT_GetString:
{
Do_GetString(gFMX_ExternCallPtr->parm1, gFMX_ExternCallPtr->parm2,
gFMX_ExternCallPtr->parm3, reinterpret_cast<FMX_Unichar*>(gFMX_ExternCallPtr->result));
}
break;
}// switch whichCall
} // FMExternCallProc
Step Three - Do_PluginIdle function
In your main file, you will find the 'Do_PluginIdle' function.
static void Do_PluginIdle(FMX_IdleLevel idleLevel)
{
if (pluginIsRunningOnFMPro) // Only execute if running on client or runtime (ie. don't call when on server)
{ // BOOL pluginIsRunningOnFMPro set during plugin init
// Check idle state
switch (idleLevel)
{
case kFMXT_UserIdle:
{
// The user hasn't done anything for 30 seconds or more. (mouse movement don't reset this)
}
break;
case kFMXT_UserNotIdle:
{
// The user has done something within the last 30 seconds
}
break;
case kFMXT_ScriptPaused:
{
// The user is running a script that is paused
}
break;
case kFMXT_ScriptRunning:
{
// The user is running a script
}
break;
case kFMXT_Unsafe:
{
// The plug-in should wait and do nothing at this time.
}
break;
}// switch idleLevel
}
} // Do_PluginIdle
Example 1 : Execute queued SQL
The following example shows how to execute a callback to FileMaker of a queued ExecuteSQL