FB_FileClose
With this function block the file can be closed, and thereby placed into a defined state for further processing by other programs.
VAR_INPUT
VAR_INPUT
sNetId : T_AmsNetId;
hFile : UINT;
bExecute : BOOL;
tTimeout : TIME;
END_VAR
sNetId : Is a string containing the AMS network identifier of the target device to which the ADS command is directed.
hFile : Is occupied by the file handle created with FB_FileOpen.
bExecute : The ADS command is triggered by a rising edge at this input.
tTimeout : States the time before the function is cancelled.
VAR_OUTPUT
VAR_OUTPUT
bBusy : BOOL;
bError : BOOL;
nErrId : UDINT;
END_VAR
bBusy: This output remains TRUE until the block has executed a command, but at the longest for the duration supplied to the ‘tTimeout’ input. While bBusy = TRUE, no new command will be accepted at the inputs. Please note that it is not the execution of the service but its acceptance whose time is monitored.
bError: This output is switched to TRUE if an error occurs during the execution of a command. The command-specific error code is contained in ‘nErrId’.
nErrId: Contains the command-specific ADS error code of the most recently executed command.
Function specific ADS error code | Possible reason |
---|---|
0x703 | Invalid or unknown file handle. |
0x70E | File was opened with wrong method ( e.g. with 'obsolete' FILEOPEN function block ). |
Example of calling the block in FBD:
PROGRAM Test
VAR
fbFileClose : FB_FileClose;
hFile : UINT;
bFileClose : BOOL;
bFileCloseBusy : BOOL;
bFileCloseError : BOOL;
nFileCloseErrorId: UDINT;
END_VAR
Here the file associated with the file handle (which was itself generated by ”FB_FileOpen") is closed again.
Requirements
Development environment | Target system type | PLC libraries to include |
---|---|---|
TwinCAT v2.8.0 | PC or CX (x86) | TcSystem.Lib |
TwinCAT v2.10.0 Build >= 1301 | CX (ARM) | TcSystem.Lib |