Modified Files: glib/ChangeLog glib/glib/giochannel.c glib/glib/giounix.c

Modified Files:
	glib/ChangeLog glib/glib/giochannel.c glib/glib/giounix.c
	glib/glib/giochannel.h glib/glib/glib.def
	glib/docs/reference/ChangeLog
	glib/docs/reference/glib/glib-sections.txt

	* glib/giochannel.c glib/glib.def glib/giochannel.h: Added
	new functions g_io_channel_[set,get]_close_on_unref ()

	* glib/giochannel.c: glib/giochannel.h: Documentation fixes

	* glib/giochannel.c: Fixed g_io_channel_write_chars ()
	so that bytes_written is always set to an appropriate
	value when it returns

	* glib/giounix.c: changed g_io_channel_get_flags () to
	set the is_readable and is_writeable flags cached
	by the channel

	* docs/reference/glib/glib-sections.txt: Added
	declarations for g_io_channel_[set,get]_close_on_unref
This commit is contained in:
Ron Steinke 2001-08-16 23:02:53 +00:00
parent a80fc07f32
commit e7931debd2
14 changed files with 294 additions and 106 deletions

View File

@ -1,3 +1,18 @@
2001-08-15 Ron Steinke <rsteinke@w-link.net>
* glib/giochannel.c glib/glib.def glib/giochannel.h: Added
new functions g_io_channel_[set,get]_close_on_unref ()
* glib/giochannel.c: glib/giochannel.h: Documentation fixes
* glib/giochannel.c: Fixed g_io_channel_write_chars ()
so that bytes_written is always set to an appropriate
value when it returns
* glib/giounix.c: changed g_io_channel_get_flags () to
set the is_readable and is_writeable flags cached
by the channel
Wed Aug 15 11:09:56 2001 Tim Janik <timj@gtk.org> Wed Aug 15 11:09:56 2001 Tim Janik <timj@gtk.org>
* Makefile.am: let the generated .pc files depend on config.status, * Makefile.am: let the generated .pc files depend on config.status,

View File

@ -1,3 +1,18 @@
2001-08-15 Ron Steinke <rsteinke@w-link.net>
* glib/giochannel.c glib/glib.def glib/giochannel.h: Added
new functions g_io_channel_[set,get]_close_on_unref ()
* glib/giochannel.c: glib/giochannel.h: Documentation fixes
* glib/giochannel.c: Fixed g_io_channel_write_chars ()
so that bytes_written is always set to an appropriate
value when it returns
* glib/giounix.c: changed g_io_channel_get_flags () to
set the is_readable and is_writeable flags cached
by the channel
Wed Aug 15 11:09:56 2001 Tim Janik <timj@gtk.org> Wed Aug 15 11:09:56 2001 Tim Janik <timj@gtk.org>
* Makefile.am: let the generated .pc files depend on config.status, * Makefile.am: let the generated .pc files depend on config.status,

View File

@ -1,3 +1,18 @@
2001-08-15 Ron Steinke <rsteinke@w-link.net>
* glib/giochannel.c glib/glib.def glib/giochannel.h: Added
new functions g_io_channel_[set,get]_close_on_unref ()
* glib/giochannel.c: glib/giochannel.h: Documentation fixes
* glib/giochannel.c: Fixed g_io_channel_write_chars ()
so that bytes_written is always set to an appropriate
value when it returns
* glib/giounix.c: changed g_io_channel_get_flags () to
set the is_readable and is_writeable flags cached
by the channel
Wed Aug 15 11:09:56 2001 Tim Janik <timj@gtk.org> Wed Aug 15 11:09:56 2001 Tim Janik <timj@gtk.org>
* Makefile.am: let the generated .pc files depend on config.status, * Makefile.am: let the generated .pc files depend on config.status,

View File

@ -1,3 +1,18 @@
2001-08-15 Ron Steinke <rsteinke@w-link.net>
* glib/giochannel.c glib/glib.def glib/giochannel.h: Added
new functions g_io_channel_[set,get]_close_on_unref ()
* glib/giochannel.c: glib/giochannel.h: Documentation fixes
* glib/giochannel.c: Fixed g_io_channel_write_chars ()
so that bytes_written is always set to an appropriate
value when it returns
* glib/giounix.c: changed g_io_channel_get_flags () to
set the is_readable and is_writeable flags cached
by the channel
Wed Aug 15 11:09:56 2001 Tim Janik <timj@gtk.org> Wed Aug 15 11:09:56 2001 Tim Janik <timj@gtk.org>
* Makefile.am: let the generated .pc files depend on config.status, * Makefile.am: let the generated .pc files depend on config.status,

View File

@ -1,3 +1,18 @@
2001-08-15 Ron Steinke <rsteinke@w-link.net>
* glib/giochannel.c glib/glib.def glib/giochannel.h: Added
new functions g_io_channel_[set,get]_close_on_unref ()
* glib/giochannel.c: glib/giochannel.h: Documentation fixes
* glib/giochannel.c: Fixed g_io_channel_write_chars ()
so that bytes_written is always set to an appropriate
value when it returns
* glib/giounix.c: changed g_io_channel_get_flags () to
set the is_readable and is_writeable flags cached
by the channel
Wed Aug 15 11:09:56 2001 Tim Janik <timj@gtk.org> Wed Aug 15 11:09:56 2001 Tim Janik <timj@gtk.org>
* Makefile.am: let the generated .pc files depend on config.status, * Makefile.am: let the generated .pc files depend on config.status,

View File

@ -1,3 +1,18 @@
2001-08-15 Ron Steinke <rsteinke@w-link.net>
* glib/giochannel.c glib/glib.def glib/giochannel.h: Added
new functions g_io_channel_[set,get]_close_on_unref ()
* glib/giochannel.c: glib/giochannel.h: Documentation fixes
* glib/giochannel.c: Fixed g_io_channel_write_chars ()
so that bytes_written is always set to an appropriate
value when it returns
* glib/giounix.c: changed g_io_channel_get_flags () to
set the is_readable and is_writeable flags cached
by the channel
Wed Aug 15 11:09:56 2001 Tim Janik <timj@gtk.org> Wed Aug 15 11:09:56 2001 Tim Janik <timj@gtk.org>
* Makefile.am: let the generated .pc files depend on config.status, * Makefile.am: let the generated .pc files depend on config.status,

View File

@ -1,3 +1,18 @@
2001-08-15 Ron Steinke <rsteinke@w-link.net>
* glib/giochannel.c glib/glib.def glib/giochannel.h: Added
new functions g_io_channel_[set,get]_close_on_unref ()
* glib/giochannel.c: glib/giochannel.h: Documentation fixes
* glib/giochannel.c: Fixed g_io_channel_write_chars ()
so that bytes_written is always set to an appropriate
value when it returns
* glib/giounix.c: changed g_io_channel_get_flags () to
set the is_readable and is_writeable flags cached
by the channel
Wed Aug 15 11:09:56 2001 Tim Janik <timj@gtk.org> Wed Aug 15 11:09:56 2001 Tim Janik <timj@gtk.org>
* Makefile.am: let the generated .pc files depend on config.status, * Makefile.am: let the generated .pc files depend on config.status,

View File

@ -1,3 +1,18 @@
2001-08-15 Ron Steinke <rsteinke@w-link.net>
* glib/giochannel.c glib/glib.def glib/giochannel.h: Added
new functions g_io_channel_[set,get]_close_on_unref ()
* glib/giochannel.c: glib/giochannel.h: Documentation fixes
* glib/giochannel.c: Fixed g_io_channel_write_chars ()
so that bytes_written is always set to an appropriate
value when it returns
* glib/giounix.c: changed g_io_channel_get_flags () to
set the is_readable and is_writeable flags cached
by the channel
Wed Aug 15 11:09:56 2001 Tim Janik <timj@gtk.org> Wed Aug 15 11:09:56 2001 Tim Janik <timj@gtk.org>
* Makefile.am: let the generated .pc files depend on config.status, * Makefile.am: let the generated .pc files depend on config.status,

View File

@ -1,3 +1,8 @@
2001-08-15 Ron Stenike <rsteinke@w-link.net>
* docs/reference/glib/glib-sections.txt: Added
declarations for g_io_channel_[set,get]_close_on_unref
Sun Aug 12 10:03:42 2001 Owen Taylor <otaylor@redhat.com> Sun Aug 12 10:03:42 2001 Owen Taylor <otaylor@redhat.com>
* */Makefile.am: Set GPATH to fix srcdir != builddir * */Makefile.am: Set GPATH to fix srcdir != builddir

View File

@ -640,6 +640,8 @@ g_io_channel_get_buffered
g_io_channel_set_buffered g_io_channel_set_buffered
g_io_channel_get_encoding g_io_channel_get_encoding
g_io_channel_set_encoding g_io_channel_set_encoding
g_io_channel_get_close_on_unref
g_io_channel_set_close_on_unref
<SUBSECTION Private> <SUBSECTION Private>
g_io_channel_win32_new_fd g_io_channel_win32_new_fd

View File

@ -328,7 +328,7 @@ g_io_channel_close (GIOChannel *channel)
* @err: location to store a #GIOChannelError * @err: location to store a #GIOChannelError
* *
* Close an IO channel. Any pending data to be written will be * Close an IO channel. Any pending data to be written will be
* flushed. The channel will not be freed until the * flushed if @flush is %TRUE. The channel will not be freed until the
* last reference is dropped using g_io_channel_unref(). * last reference is dropped using g_io_channel_unref().
* *
* Return value: * Return value:
@ -479,9 +479,10 @@ g_io_add_watch (GIOChannel *channel,
* g_io_channel_get_buffer_condition: * g_io_channel_get_buffer_condition:
* @channel: A #GIOChannel * @channel: A #GIOChannel
* *
* This function returns a #GIOCondition depending on the status of the * 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 * internal buffers in the #GIOChannel. Only the flags %G_IO_IN and
* %G_IO_OUT will be set. * %G_IO_OUT may be set.
* *
* Return value: A #GIOCondition * Return value: A #GIOCondition
**/ **/
@ -624,6 +625,9 @@ g_io_channel_get_buffer_size (GIOChannel *channel)
* g_io_channel_set_line_term: * g_io_channel_set_line_term:
* @channel: a #GIOChannel * @channel: a #GIOChannel
* @line_term: The line termination string. Use %NULL for auto detect. * @line_term: The line termination string. Use %NULL for auto detect.
* Auto detection breaks on "\n", "\r\n", "\r", and
* the unicode paragraph separator. Auto detection should
* not be used for anything other than file-based channels.
* *
* This sets the string that #GIOChannel uses to determine * This sets the string that #GIOChannel uses to determine
* where in the file a line break occurs. * where in the file a line break occurs.
@ -689,6 +693,13 @@ g_io_channel_set_flags (GIOChannel *channel,
* Gets the current flags for a #GIOChannel, including read-only * Gets the current flags for a #GIOChannel, including read-only
* flags such as %G_IO_FLAG_IS_READABLE. * flags such as %G_IO_FLAG_IS_READABLE.
* *
* The values of the flags %G_IO_FLAG_IS_READABLE and %G_IO_FLAG_IS_WRITEABLE
* 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.
*
* Return value: the flags which are set on the channel * Return value: the flags which are set on the channel
**/ **/
GIOFlags GIOFlags
@ -712,13 +723,51 @@ g_io_channel_get_flags (GIOChannel *channel)
return flags; return flags;
} }
/**
* g_io_channel_set_close_on_unref:
* @channel: a #GIOChannel
* @do_close: 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.
**/
void
g_io_channel_set_close_on_unref (GIOChannel *channel,
gboolean do_close)
{
g_return_if_fail (channel != NULL);
channel->close_on_unref = do_close;
}
/**
* g_io_channel_get_close_on_unref:
* @channel: a #GIOChannel
*
* Return value: Whether the channel will be closedi 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.
**/
gboolean
g_io_channel_get_close_on_unref (GIOChannel *channel)
{
g_return_val_if_fail (channel != NULL, FALSE);
return channel->close_on_unref;
}
/** /**
* g_io_channel_seek_position: * g_io_channel_seek_position:
* @channel: a #GIOChannel * @channel: a #GIOChannel
* @offset: The offset in bytes from the position specified by @type * @offset: The offset in bytes from the position specified by @type
* @type: a #GSeekType. The type %G_SEEK_CUR is only allowed if * @type: a #GSeekType. The type %G_SEEK_CUR is only allowed in those
* the channel has the default encoding or the * cases where a call to g_io_channel_set_encoding ()
* encoding %G_IO_CHANNEL_ENCODE_RAW for raw file access. * is allowed. See the documentation for
* g_io_channel_set_encoding () for details.
* @error: A location to return an error of type #GIOChannelError * @error: A location to return an error of type #GIOChannelError
* *
* Replacement for g_io_channel_seek() with the new API. * Replacement for g_io_channel_seek() with the new API.
@ -863,6 +912,21 @@ g_io_channel_flush (GIOChannel *channel,
* The buffering state can only be set if the channel's encoding * The buffering state can only be set if the channel's encoding
* is %NULL. For any other encoding, the channel must be buffered. * 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. * The default state of the channel is buffered.
**/ **/
void void
@ -909,23 +973,35 @@ g_io_channel_get_buffered (GIOChannel *channel)
* external file is UTF-8. * external file is UTF-8.
* *
* The encoding %NULL is safe to use with binary data. * The encoding %NULL is safe to use with binary data.
* Encodings other than %NULL must use a buffered channel.
* Encodings other than %NULL and UTF-8 cannot
* use g_io_channel_seek_position() with seek type %G_SEEK_CUR,
* and cannot mix reading and writing if the channel is
* a file without first doing a seek of type %G_SEEK_SET or
* %G_SEEK_END.
* *
* The encoding can only be set under three conditions: * The encoding can only be set under the following conditions:
* *
* 1. The channel was just created, and has not been written to * 1. The channel was just created, and has not been written to
* or read from yet. * or read from yet.
* *
* 2. The channel is a file, and the file pointer was just * 2. The channel is write-only.
*
* 3. The channel is a file, and the file pointer was just
* repositioned by a call to g_io_channel_seek_position(). * repositioned by a call to g_io_channel_seek_position().
* (This flushes all the internal buffers.) * (This flushes all the internal buffers.)
* *
* 3. The current encoding is %NULL or UTF-8. * 4. The current encoding is %NULL or UTF-8.
*
* 5. 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).
*
* 6. 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 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.
* *
* Return Value: %G_IO_STATUS_NORMAL if the encoding was succesfully set. * Return Value: %G_IO_STATUS_NORMAL if the encoding was succesfully set.
**/ **/
@ -1058,10 +1134,8 @@ g_io_channel_set_encoding (GIOChannel *channel,
* @channel: a #GIOChannel * @channel: a #GIOChannel
* *
* Get the encoding for the input/output of the channel. The internal * Get the encoding for the input/output of the channel. The internal
* encoding is always UTF-8. The encoding %G_IO_CHANNEL_ENCODE_RAW * encoding is always UTF-8. The encoding %NULL makes the
* disables encoding and turns off internal buffering. Both * channel safe for binary data.
* %G_IO_CHANNEL_ENCODE_RAW and the default (no encoding, but buffered)
* are safe to use with binary data.
* *
* Return value: A string containing the encoding, this string is * Return value: A string containing the encoding, this string is
* owned by GLib and must not be freed. * owned by GLib and must not be freed.
@ -1258,7 +1332,7 @@ reencode:
* @error: A location to return an error of type #GConvertError * @error: A location to return an error of type #GConvertError
* or #GIOChannelError * or #GIOChannelError
* *
* Read a line, not including the terminating character(s), * Read a line, including the terminating character(s),
* from a #GIOChannel into a newly allocated string. * from a #GIOChannel into a newly allocated string.
* @length will contain allocated memory if the return * @length will contain allocated memory if the return
* is %G_IO_STATUS_NORMAL. * is %G_IO_STATUS_NORMAL.
@ -1303,8 +1377,8 @@ g_io_channel_read_line (GIOChannel *channel,
* g_io_channel_read_line_string: * g_io_channel_read_line_string:
* @channel: a #GIOChannel * @channel: a #GIOChannel
* @buffer: a #GString into which the line will be written. * @buffer: a #GString into which the line will be written.
* If @buffer already contains data, the new data will * If @buffer already contains data, the old data will
* be appended to it. * be overwritten.
* @terminator_pos: location to store position of line terminator, or %NULL * @terminator_pos: location to store position of line terminator, or %NULL
* @error: a location to store an error of type #GConvertError * @error: a location to store an error of type #GConvertError
* or #GIOChannelError * or #GIOChannelError
@ -1526,11 +1600,10 @@ done:
* @error: A location to return an error of type #GConvertError * @error: A location to return an error of type #GConvertError
* or #GIOChannelError * or #GIOChannelError
* *
* Read all the remaining data from the file. Parameters as * Read all the remaining data from the file.
* for g_io_channel_read_line.
* *
* Return value: One of #G_IO_STATUS_EOF or #G_IO_STATUS_PARTIAL_CHARS * Return value: %G_IO_STATUS_NORMAL on success. This function never
* on success * returns %G_IO_STATUS_EOF.
**/ **/
GIOStatus GIOStatus
g_io_channel_read_to_end (GIOChannel *channel, g_io_channel_read_to_end (GIOChannel *channel,
@ -1602,7 +1675,10 @@ g_io_channel_read_to_end (GIOChannel *channel,
* not be complelely filled even if there is data * not be complelely filled even if there is data
* in the buffer if the remaining data is not a * in the buffer if the remaining data is not a
* complete character. * complete character.
* @bytes_read: The number of bytes read. * @bytes_read: The number of bytes read. This may be zero even on
* success if count < 6 and the channel's encoding is non-%NULL.
* This indicates that the next UTF-8 character is too wide for
* the buffer.
* @error: A location to return an error of type #GConvertError * @error: A location to return an error of type #GConvertError
* or #GIOChannelError. * or #GIOChannelError.
* *
@ -1685,7 +1761,7 @@ g_io_channel_read_chars (GIOChannel *channel,
{ {
prevchar = nextchar; prevchar = nextchar;
nextchar = g_utf8_next_char (nextchar); nextchar = g_utf8_next_char (nextchar);
g_assert (nextchar != prevchar); /* Posibile for *prevchar of -1 or -2 */ g_assert (nextchar != prevchar); /* Possible for *prevchar of -1 or -2 */
} }
while (nextchar < channel->encoded_read_buf->str + got_bytes); while (nextchar < channel->encoded_read_buf->str + got_bytes);
@ -1772,11 +1848,19 @@ g_io_channel_read_unichar (GIOChannel *channel,
* is taken to be a nul terminated string. * is taken to be a nul terminated string.
* @bytes_written: The number of bytes written. This can be nonzero * @bytes_written: The number of bytes written. This can be nonzero
* even if the return value is not %G_IO_STATUS_NORMAL. * even if the return value is not %G_IO_STATUS_NORMAL.
* If the return value is %G_IO_STATUS_NORMAL and the
* channel is blocking, this will always be equal
* to @count if @count >= 0.
* @error: A location to return an error of type #GConvertError * @error: A location to return an error of type #GConvertError
* or #GIOChannelError * or #GIOChannelError
* *
* Replacement for g_io_channel_write() with the new API. * 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 ().
*
* Return value: * Return value:
**/ **/
GIOStatus GIOStatus
@ -1798,7 +1882,11 @@ g_io_channel_write_chars (GIOChannel *channel,
count = strlen (buf); count = strlen (buf);
if (count == 0) if (count == 0)
{
if (bytes_written)
*bytes_written = 0;
return G_IO_STATUS_NORMAL; return G_IO_STATUS_NORMAL;
}
g_return_val_if_fail (buf != NULL, G_IO_STATUS_ERROR); g_return_val_if_fail (buf != NULL, G_IO_STATUS_ERROR);
g_return_val_if_fail (count > 0, G_IO_STATUS_ERROR); g_return_val_if_fail (count > 0, G_IO_STATUS_ERROR);
@ -1824,8 +1912,12 @@ g_io_channel_write_chars (GIOChannel *channel,
} }
status = g_io_channel_seek_position (channel, 0, G_SEEK_CUR, error); status = g_io_channel_seek_position (channel, 0, G_SEEK_CUR, error);
if (status != G_IO_STATUS_NORMAL) if (status != G_IO_STATUS_NORMAL)
{
if (bytes_written)
*bytes_written = 0;
return status; return status;
} }
}
if (!channel->write_buf) if (!channel->write_buf)
channel->write_buf = g_string_sized_new (channel->buf_size); channel->write_buf = g_string_sized_new (channel->buf_size);
@ -1978,6 +2070,8 @@ reconvert:
memcpy (channel->partial_write_buf, from_buf, left_len); memcpy (channel->partial_write_buf, from_buf, left_len);
channel->partial_write_buf[left_len] = '\0'; channel->partial_write_buf[left_len] = '\0';
if (bytes_written)
*bytes_written = count;
return G_IO_STATUS_NORMAL; return G_IO_STATUS_NORMAL;
} }
@ -2056,7 +2150,7 @@ reconvert:
} }
if (bytes_written) if (bytes_written)
*bytes_written = wrote_bytes; *bytes_written = count;
return G_IO_STATUS_NORMAL; return G_IO_STATUS_NORMAL;
} }

View File

@ -103,8 +103,6 @@ typedef enum
struct _GIOChannel struct _GIOChannel
{ {
/*<private>*/
guint ref_count; guint ref_count;
GIOFuncs *funcs; GIOFuncs *funcs;
@ -123,20 +121,7 @@ struct _GIOChannel
gboolean use_buffer : 1; /* The encoding uses the buffers */ gboolean use_buffer : 1; /* The encoding uses the buffers */
gboolean do_encode : 1; /* The encoding uses the GIConv coverters */ gboolean do_encode : 1; /* The encoding uses the GIConv coverters */
/*<public>*/
gboolean close_on_unref : 1; /* Close the channel on final unref */ gboolean close_on_unref : 1; /* Close the channel on final unref */
/* The is_readable and is_writeable flags should really be marked
* <protected> instead of <private>. Some applications of GIOChannel,
* like GNet which implements the unix shutdown function to partially
* or completely disconnect sockets, may need to set these. For most
* cases, people won't need to touch them.
*/
/*<private>*/
gboolean is_readable : 1; /* Cached GIOFlag */ gboolean is_readable : 1; /* Cached GIOFlag */
gboolean is_writeable : 1; /* ditto */ gboolean is_writeable : 1; /* ditto */
gboolean is_seekable : 1; /* ditto */ gboolean is_seekable : 1; /* ditto */
@ -228,6 +213,9 @@ GIOStatus g_io_channel_set_encoding (GIOChannel *channel,
const gchar *encoding, const gchar *encoding,
GError **error); GError **error);
G_CONST_RETURN gchar* g_io_channel_get_encoding (GIOChannel *channel); G_CONST_RETURN gchar* g_io_channel_get_encoding (GIOChannel *channel);
void g_io_channel_set_close_on_unref (GIOChannel *channel,
gboolean do_close);
gboolean g_io_channel_get_close_on_unref (GIOChannel *channel);
GIOStatus g_io_channel_flush (GIOChannel *channel, GIOStatus g_io_channel_flush (GIOChannel *channel,

View File

@ -340,34 +340,24 @@ g_io_unix_create_watch (GIOChannel *channel,
return source; return source;
} }
static const GIOFlags g_io_unix_fcntl_flags[] = {
G_IO_FLAG_APPEND,
G_IO_FLAG_NONBLOCK,
};
static const glong g_io_unix_fcntl_posix_flags[] = {
O_APPEND,
#ifdef O_NONBLOCK
O_NONBLOCK,
#else
O_NDELAY,
#endif
};
#define G_IO_UNIX_NUM_FCNTL_FLAGS G_N_ELEMENTS (g_io_unix_fcntl_flags)
static GIOStatus static GIOStatus
g_io_unix_set_flags (GIOChannel *channel, g_io_unix_set_flags (GIOChannel *channel,
GIOFlags flags, GIOFlags flags,
GError **err) GError **err)
{ {
glong fcntl_flags; glong fcntl_flags;
gint loop;
GIOUnixChannel *unix_channel = (GIOUnixChannel *) channel; GIOUnixChannel *unix_channel = (GIOUnixChannel *) channel;
fcntl_flags = 0; fcntl_flags = 0;
for (loop = 0; loop < G_IO_UNIX_NUM_FCNTL_FLAGS; loop++) if (flags & G_IO_FLAG_APPEND)
if (flags & g_io_unix_fcntl_flags[loop]) fcntl_flags |= O_APPEND;
fcntl_flags |= g_io_unix_fcntl_posix_flags[loop]; if (flags & G_IO_FLAG_NONBLOCK)
#ifdef O_NONBLOCK
fcntl_flags |= O_NONBLOCK;
#else
fcntl_flags |= O_NDELAY;
#endif
if (fcntl (unix_channel->fd, F_SETFL, fcntl_flags) == -1) if (fcntl (unix_channel->fd, F_SETFL, fcntl_flags) == -1)
{ {
@ -385,7 +375,6 @@ g_io_unix_get_flags (GIOChannel *channel)
{ {
GIOFlags flags = 0; GIOFlags flags = 0;
glong fcntl_flags; glong fcntl_flags;
gint loop;
GIOUnixChannel *unix_channel = (GIOUnixChannel *) channel; GIOUnixChannel *unix_channel = (GIOUnixChannel *) channel;
fcntl_flags = fcntl (unix_channel->fd, F_GETFL); fcntl_flags = fcntl (unix_channel->fd, F_GETFL);
@ -397,9 +386,32 @@ g_io_unix_get_flags (GIOChannel *channel)
return 0; return 0;
} }
for (loop = 0; loop < G_IO_UNIX_NUM_FCNTL_FLAGS; loop++) if (fcntl_flags & O_APPEND)
if (fcntl_flags & g_io_unix_fcntl_posix_flags[loop]) flags |= G_IO_FLAG_APPEND;
flags |= g_io_unix_fcntl_flags[loop]; #ifdef O_NONBLOCK
if (fcntl_flags & O_NONBLOCK)
#else
if (fcntl_flags & O_NDELAY)
#endif
flags |= G_IO_FLAG_NONBLOCK;
switch (fcntl_flags & (O_RDONLY | O_WRONLY | O_RDWR))
{
case O_RDONLY:
channel->is_readable = TRUE;
channel->is_writeable = FALSE;
break;
case O_WRONLY:
channel->is_readable = FALSE;
channel->is_writeable = TRUE;
break;
case O_RDWR:
channel->is_readable = TRUE;
channel->is_writeable = TRUE;
break;
default:
g_assert_not_reached ();
}
return flags; return flags;
} }
@ -540,7 +552,6 @@ g_io_channel_unix_new (gint fd)
struct stat buffer; struct stat buffer;
GIOUnixChannel *unix_channel = g_new (GIOUnixChannel, 1); GIOUnixChannel *unix_channel = g_new (GIOUnixChannel, 1);
GIOChannel *channel = (GIOChannel *)unix_channel; GIOChannel *channel = (GIOChannel *)unix_channel;
int flags;
g_io_channel_init (channel); g_io_channel_init (channel);
channel->funcs = &unix_channel_funcs; channel->funcs = &unix_channel_funcs;
@ -557,44 +568,10 @@ g_io_channel_unix_new (gint fd)
else /* Assume not seekable */ else /* Assume not seekable */
channel->is_seekable = FALSE; channel->is_seekable = FALSE;
flags = fcntl (fd, F_GETFL);
if (flags != -1)
{
/* Don't know if fcntl flags overlap, be careful */
if (flags & O_WRONLY)
{
channel->is_readable = FALSE;
channel->is_writeable = TRUE;
}
else if (flags & O_RDWR)
channel->is_readable = channel->is_writeable = TRUE;
#if O_RDONLY == 0
else /* O_RDONLY defined as zero on linux (elsewhere?) */
{
channel->is_readable = TRUE;
channel->is_writeable = FALSE;
}
#else /* O_RDONLY == 0 */
else if (flags & O_RDONLY)
{
channel->is_readable = TRUE;
channel->is_writeable = FALSE;
}
else
channel->is_readable = channel->is_writeable = FALSE;
#endif /* O_RDONLY == 0 */
}
else
{
g_warning (G_STRLOC "Error while getting flags for FD: %s (%d)\n",
g_strerror (errno), errno);
g_free (channel);
return NULL;
}
unix_channel->fd = fd; unix_channel->fd = fd;
g_io_unix_get_flags (channel); /* Sets is_readable, is_writeable */
return channel; return channel;
} }

View File

@ -194,6 +194,7 @@ EXPORTS
g_io_channel_get_buffer_condition g_io_channel_get_buffer_condition
g_io_channel_get_buffer_size g_io_channel_get_buffer_size
g_io_channel_get_buffered g_io_channel_get_buffered
g_io_channel_get_close_of_unref
g_io_channel_get_encoding g_io_channel_get_encoding
g_io_channel_get_flags g_io_channel_get_flags
g_io_channel_get_line_term g_io_channel_get_line_term
@ -210,6 +211,7 @@ EXPORTS
g_io_channel_seek_position g_io_channel_seek_position
g_io_channel_set_buffer_size g_io_channel_set_buffer_size
g_io_channel_set_buffered g_io_channel_set_buffered
g_io_channel_set_close_of_unref
g_io_channel_set_encoding g_io_channel_set_encoding
g_io_channel_set_flags g_io_channel_set_flags
g_io_channel_set_line_term g_io_channel_set_line_term