FileSeek
Function Block - Sets the current position in an open file.
Inputs
Input |
Data Type |
Range |
Unit |
Default |
Description |
---|---|---|---|---|---|
Execute |
BOOL |
0 to 1 |
N/A |
No default |
On the rising edge, test if the end of the file is reached in a file that is open for reading. |
ID |
UDINT |
N/A |
N/A |
No default |
The ID of the open file. |
POS |
DINT |
N/A |
N/A |
No default |
Number of bytes to offset from ORG.
|
ORG |
DINT |
|
N/A |
No default |
Origin of the move.
|
Outputs
Output |
Data Type |
Range |
Unit |
Description |
---|---|---|---|---|
Done |
BOOL |
|
|
If TRUE, the command completed successfully. |
Error |
BOOL |
|
|
If TRUE, an error has occurred. |
ErrorID |
DINT |
|
|
Indicates the error if Error output is TRUE. See the table in File and TCP/IP Function Block ErrorIDs. |
Remarks
Figure 1: FileCopy
FBD Language Example
Not available.
FFLD Language Example
Not available.
IL Language Example
Not available.
ST Language Example
(* FileSeek example *)
CASE StepCounter OF
0:
(* Move to beginning of the file *)
Inst_FileSeek(TRUE, MyInputFileID, 0, SEEK_SET);
StepCounter := StepCounter + 1;
1:
Inst_FileSeek(TRUE, MyInputFileID, 0, SEEK_SET);
IF Inst_FileSeek.Done THEN
Inst_FileSeek(FALSE, 0, 0, SEEK_SET);
StepCounter := StepCounter + 1;
END_IF;
END_CASE;
See Also