Gjsify LogoGjsify Logo

A data structure representing an IO Channel. The fields should be considered private and should only be accessed with the following functions.

record

Hierarchy

  • IOChannel

Index

Constructors

Properties

name: string

Methods

  • close(): void
  • Close an IO channel. Any pending data to be written will be flushed, ignoring errors. The channel will not be freed until the last reference is dropped using g_io_channel_unref().

    Returns void

  • This function returns a #GIOCondition depending on whether there is data to be read/space to write data in the internal buffers in the #GIOChannel. Only the flags %G_IO_IN and %G_IO_OUT may be set.

    Returns IOCondition

  • get_buffer_size(): number
  • get_buffered(): boolean
  • get_close_on_unref(): boolean
  • Returns whether the file/socket/whatever associated with channel will be closed when channel receives its final unref and is destroyed. The default value of this is %TRUE for channels created by g_io_channel_new_file (), and %FALSE for all other channels.

    Returns boolean

  • get_encoding(): string
  • Gets the encoding for the input/output of the channel. The internal encoding is always UTF-8. The encoding %NULL makes the channel safe for binary data.

    Returns string

  • Gets the current flags for a #GIOChannel, including read-only flags such as %G_IO_FLAG_IS_READABLE.

    The values of the flags %G_IO_FLAG_IS_READABLE and %G_IO_FLAG_IS_WRITABLE are cached for internal use by the channel when it is created. If they should change at some later point (e.g. partial shutdown of a socket with the UNIX shutdown() function), the user should immediately call g_io_channel_get_flags() to update the internal values of these flags.

    Returns IOFlags

  • get_line_term(length: number): string
  • This returns the string that #GIOChannel uses to determine where in the file a line break occurs. A value of %NULL indicates autodetection.

    Parameters

    • length: number

      a location to return the length of the line terminator

    Returns string

  • init(): void
  • Initializes a #GIOChannel struct.

    This is called by each of the above functions when creating a #GIOChannel, and so is not often needed by the application programmer (unless you are creating a new type of #GIOChannel).

    Returns void

  • read(buf: string, count: number, bytes_read: number): IOError
  • Reads data from a #GIOChannel.

    Parameters

    • buf: string

      a buffer to read the data into (which should be at least count bytes long)

    • count: number

      the number of bytes to read from the #GIOChannel

    • bytes_read: number

      returns the number of bytes actually read

    Returns IOError

  • read_chars(): [IOStatus, Uint8Array, number]
  • read_line(): [IOStatus, string, number, number]
  • Reads a line, including the terminating character(s), from a #GIOChannel into a newly-allocated string. str_return will contain allocated memory if the return is %G_IO_STATUS_NORMAL.

    Returns [IOStatus, string, number, number]

  • Reads a line from a #GIOChannel, using a #GString as a buffer.

    Parameters

    • buffer: GLib.String

      a #GString into which the line will be written. If buffer already contains data, the old data will be overwritten.

    • terminator_pos: number

      location to store position of line terminator, or %NULL

    Returns IOStatus

  • Sets the current position in the #GIOChannel, similar to the standard library function fseek().

    Parameters

    • offset: number

      an offset, in bytes, which is added to the position specified by type

    • type: GLib.SeekType

      the position in the file, which can be %G_SEEK_CUR (the current position), %G_SEEK_SET (the start of the file), or %G_SEEK_END (the end of the file)

    Returns IOError

  • Replacement for g_io_channel_seek() with the new API.

    Parameters

    • offset: number

      The offset in bytes from the position specified by type

    • type: GLib.SeekType

      a #GSeekType. The type %G_SEEK_CUR is only allowed in those cases where a call to g_io_channel_set_encoding () is allowed. See the documentation for g_io_channel_set_encoding () for details.

    Returns IOStatus

  • set_buffer_size(size: number): void
  • Sets the buffer size.

    Parameters

    • size: number

      the size of the buffer, or 0 to let GLib pick a good size

    Returns void

  • set_buffered(buffered: boolean): void
  • The buffering state can only be set if the channel's encoding is %NULL. For any other encoding, the channel must be buffered.

    A buffered channel can only be set unbuffered if the channel's internal buffers have been flushed. Newly created channels or channels which have returned %G_IO_STATUS_EOF not require such a flush. For write-only channels, a call to g_io_channel_flush () is sufficient. For all other channels, the buffers may be flushed by a call to g_io_channel_seek_position (). This includes the possibility of seeking with seek type %G_SEEK_CUR and an offset of zero. Note that this means that socket-based channels cannot be set unbuffered once they have had data read from them.

    On unbuffered channels, it is safe to mix read and write calls from the new and old APIs, if this is necessary for maintaining old code.

    The default state of the channel is buffered.

    Parameters

    • buffered: boolean

      whether to set the channel buffered or unbuffered

    Returns void

  • set_close_on_unref(do_close: boolean): void
  • Whether to close the channel on the final unref of the #GIOChannel data structure. The default value of this is %TRUE for channels created by g_io_channel_new_file (), and %FALSE for all other channels.

    Setting this flag to %TRUE for a channel you have already closed can cause problems when the final reference to the #GIOChannel is dropped.

    Parameters

    • do_close: boolean

      Whether to close the channel on the final unref of the GIOChannel data structure.

    Returns void

  • set_encoding(encoding: string): IOStatus
  • Sets the encoding for the input/output of the channel. The internal encoding is always UTF-8. The default encoding for the external file is UTF-8.

    The encoding %NULL is safe to use with binary data.

    The encoding can only be set if one of the following conditions is true:

    • The channel was just created, and has not been written to or read from yet.

    • The channel is write-only.

    • The channel is a file, and the file pointer was just repositioned by a call to g_io_channel_seek_position(). (This flushes all the internal buffers.)

    • The current encoding is %NULL or UTF-8.

    • One of the (new API) read functions has just returned %G_IO_STATUS_EOF (or, in the case of g_io_channel_read_to_end(), %G_IO_STATUS_NORMAL).

    • One of the functions g_io_channel_read_chars() or g_io_channel_read_unichar() has returned %G_IO_STATUS_AGAIN or %G_IO_STATUS_ERROR. This may be useful in the case of %G_CONVERT_ERROR_ILLEGAL_SEQUENCE. Returning one of these statuses from g_io_channel_read_line(), g_io_channel_read_line_string(), or g_io_channel_read_to_end() does not guarantee that the encoding can be changed.

    Channels which do not meet one of the above conditions cannot call g_io_channel_seek_position() with an offset of %G_SEEK_CUR, and, if they are "seekable", cannot call g_io_channel_write_chars() after calling one of the API "read" functions.

    Parameters

    • encoding: string

      the encoding type

    Returns IOStatus

  • set_line_term(line_term: string, length: number): void
  • This sets the string that #GIOChannel uses to determine where in the file a line break occurs.

    Parameters

    • line_term: string

      The line termination string. Use %NULL for autodetect. Autodetection breaks on "\n", "\r\n", "\r", "\0", and the Unicode paragraph separator. Autodetection should not be used for anything other than file-based channels.

    • length: number

      The length of the termination string. If -1 is passed, the string is assumed to be nul-terminated. This option allows termination strings with embedded nuls.

    Returns void

  • Close an IO channel. Any pending data to be written will be flushed if flush is %TRUE. The channel will not be freed until the last reference is dropped using g_io_channel_unref().

    Parameters

    • flush: boolean

      if %TRUE, flush pending

    Returns IOStatus

  • unix_get_fd(): number
  • Returns the file descriptor of the #GIOChannel.

    On Windows this function returns the file descriptor or socket of the #GIOChannel.

    Returns number

  • unref(): void
  • write(buf: string, count: number, bytes_written: number): IOError
  • Writes data to a #GIOChannel.

    Parameters

    • buf: string

      the buffer containing the data to write

    • count: number

      the number of bytes to write

    • bytes_written: number

      the number of bytes actually written

    Returns IOError

  • write_chars(buf: Uint8Array, count: number): [IOStatus, number]
  • Replacement for g_io_channel_write() with the new API.

    On seekable channels with encodings other than %NULL or UTF-8, generic mixing of reading and writing is not allowed. A call to g_io_channel_write_chars () may only be made on a channel from which data has been read in the cases described in the documentation for g_io_channel_set_encoding ().

    Parameters

    • buf: Uint8Array

      a buffer to write data from

    • count: number

      the size of the buffer. If -1, the buffer is taken to be a nul-terminated string.

    Returns [IOStatus, number]

  • write_unichar(thechar: string): IOStatus
  • Writes a Unicode character to channel. This function cannot be called on a channel with %NULL encoding.

    Parameters

    • thechar: string

      a character

    Returns IOStatus

  • error_quark(): number
  • new_file(filename: string, mode: string): IOChannel
  • Open a file filename as a #GIOChannel using mode mode. This channel will be closed when the last reference to it is dropped, so there is no need to call g_io_channel_close() (though doing so will not cause problems, as long as no attempt is made to access the channel after it is closed).

    Parameters

    • filename: string

      A string containing the name of a file

    • mode: string

      One of "r", "w", "a", "r+", "w+", "a+". These have the same meaning as in fopen()

    Returns IOChannel

  • Creates a new #GIOChannel given a file descriptor. On UNIX systems this works for plain files, pipes, and sockets.

    The returned #GIOChannel has a reference count of 1.

    The default encoding for #GIOChannel is UTF-8. If your application is reading output from a command using via pipe, you may need to set the encoding to the encoding of the current locale (see g_get_charset()) with the g_io_channel_set_encoding() function. By default, the fd passed will not be closed when the final reference to the #GIOChannel data structure is dropped.

    If you want to read raw binary data without interpretation, then call the g_io_channel_set_encoding() function with %NULL for the encoding argument.

    This function is available in GLib on Windows, too, but you should avoid using it on Windows. The domain of file descriptors and sockets overlap. There is no way for GLib to know which one you mean in case the argument you pass to this function happens to be both a valid file descriptor and socket. If that happens a warning is issued, and GLib assumes that it is the file descriptor you mean.

    Parameters

    • fd: number

      a file descriptor.

    Returns IOChannel

Legend

  • Module
  • Object literal
  • Variable
  • Function
  • Function with type parameter
  • Index signature
  • Type alias
  • Type alias with type parameter
  • Enumeration
  • Enumeration member
  • Property
  • Method
  • Interface
  • Interface with type parameter
  • Constructor
  • Property
  • Method
  • Index signature
  • Class
  • Class with type parameter
  • Constructor
  • Property
  • Method
  • Accessor
  • Index signature
  • Inherited constructor
  • Inherited property
  • Inherited method
  • Inherited accessor
  • Protected property
  • Protected method
  • Protected accessor
  • Private property
  • Private method
  • Private accessor
  • Static property
  • Static method