Automation 4 File Stream interface This file describes the interface used for reading and writing files in Automation 4. This includes text encoding conversion routines. --- About encodings All file streams always have a text encoding. The default encoding is determined by the user, before the import/export operation is started. All string operations on a stream follow the current encoding. You can change the encoding during reading/writing, and the change will only take effect from that point on. You can perform binary IO by setting the encoding to 'binary' and using strings consisting only of codepoints 0 to 255. --- Output File Stream user data object This object is passed to functions operating on an Output File Stream. --- Input File Stream user data object This object is passed to functions operating on an Input File Stream. --- Getting text encoding This function returns a string describing the current text encoding used for a file stream. function aegisub.fstream.get_encoding(stream) @stream (user data) The Input File Stream or Output File Stream to get the encoding for. Returns: String describing the encoding. This string can be used for setting the encoding later. --- Setting text encoding This function changes the current text encoding used for a file stream. function aegisub.fstream.set_encoding(stream, encoding) @stream (user data) The Input File Stream or Output File Stream to change the encoding for. @encoding (string) The new encoding to use. Returns: String describing the old encoding. --- File Pointer operations function aegisub.fstream.tell(stream) @stream (user data) The Input File Stream or Output File Stream get position of. Returns: Number, the number of bytes since the beginning of the file. function aegisub.fstream.seek(stream, length) @stream (user data) The Input File Stream or Output File Stream to seek in. @length (number) Number of bytes to skip. This can be negative. You can only seek backwards in an Output File Stream, and doing so truncates the file. Returns: nothing. function aegisub.fstream.reset(stream) Resets the file pointer to the start of the file. Truncates an Output File Stream to zero bytes. @stream (user data) The Input File Stream or Output File Stream to seek in. Returns: nothing. --- Reading text All these functions assume the file is in the current encoding specified. function aegisub.fstream.skip_utf_bom(stream, change_encoding) This function has undefined behaviour unless called as the first read-operation on the stream. It detects whether the file stream starts with an UTF Byte Order Mark, skips the number of bytes used by that BOM, and optionally changes the current file encoding to match the detected BOM. @stream (user data) The Input File Stream to read from. @change_encoding (boolean) If true, change encoding to match the detected BOM. Returns: Boolean, whether a BOM was detected or not. function aegisub.fstream.read(stream, length) Read a number of characters from a file. @stream (user data) The Input File Stream to read from. @length (number) Number of characters to read. If this is zero, no data are read. If this is larger than the number of characters available, data are read until the end of file. Returns: String, the string read from the file. function aegisub.fstream.read_bytes(stream, length) Read a number of bytes from a file and convert to a string. @stream (user data) The Input File Stream to read from. @length (number) The number of bytes to read. Returns: String, best-effort converted from the bytes read. function aegisub.fstream.read_line(stream, include_newline) Read until next newline in the file. A newline is defined asone of these sequences of Unicode codepoints in the decoded text: 0x0A ("\n") 0x0D ("\r") 0x0D 0x0A ("\r\n") The sequence "\n\r" is interpreted as two newlines, ie. a newline, a blank line and yet another newline. @stream (user data) The Input File Stream to read from. @include_newline (boolean) If true, include the newline character(s) in the returned string. Returns: String. --- Writing text All these functions assume the file is in the current encoding specified. function aegisub.fstream.write_utf_bom(stream) This function will corrupt your file if used anywhere else than on position 0. Write the correct UTF BOM character to the file, or nothing if not currently in an UTF encoding. @stream (user data) The Output File Stream to write the BOM to. Returns: nothing. function aegisub.fstream.write(stream, text) Write a string to a file. @stream (user data) The Output File Stream to write to. @text (string) The text to write. Returns: nothing. function aegisub.fstream.write_line(stream, text) Write a string to a file, followed by an "\r\n" newline. @stream (user data) The Output File Stream to write to. @text (string) The text to write. Returns: nothing. ---