| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  | /* GIO - GLib Input, Output and Streaming Library
 | 
					
						
							| 
									
										
										
										
											2008-09-02 19:05:58 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  |  * Copyright (C) 2006-2007 Red Hat, Inc. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This library is free software; you can redistribute it and/or | 
					
						
							|  |  |  |  * modify it under the terms of the GNU Lesser General Public | 
					
						
							|  |  |  |  * License as published by the Free Software Foundation; either | 
					
						
							|  |  |  |  * version 2 of the License, or (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This library is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU | 
					
						
							|  |  |  |  * Lesser General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU Lesser General | 
					
						
							|  |  |  |  * Public License along with this library; if not, write to the | 
					
						
							|  |  |  |  * Free Software Foundation, Inc., 59 Temple Place, Suite 330, | 
					
						
							|  |  |  |  * Boston, MA 02111-1307, USA. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Author: Alexander Larsson <alexl@redhat.com> | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-12-14 10:35:24 +00:00
										 |  |  | #if !defined (__GIO_GIO_H_INSIDE__) && !defined (GIO_COMPILATION)
 | 
					
						
							|  |  |  | #error "Only <gio/gio.h> can be included directly."
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  | #ifndef __G_INPUT_STREAM_H__
 | 
					
						
							|  |  |  | #define __G_INPUT_STREAM_H__
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-07-01 06:32:35 +00:00
										 |  |  | #include <gio/giotypes.h>
 | 
					
						
							| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | G_BEGIN_DECLS | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define G_TYPE_INPUT_STREAM         (g_input_stream_get_type ())
 | 
					
						
							|  |  |  | #define G_INPUT_STREAM(o)           (G_TYPE_CHECK_INSTANCE_CAST ((o), G_TYPE_INPUT_STREAM, GInputStream))
 | 
					
						
							|  |  |  | #define G_INPUT_STREAM_CLASS(k)     (G_TYPE_CHECK_CLASS_CAST((k), G_TYPE_INPUT_STREAM, GInputStreamClass))
 | 
					
						
							|  |  |  | #define G_IS_INPUT_STREAM(o)        (G_TYPE_CHECK_INSTANCE_TYPE ((o), G_TYPE_INPUT_STREAM))
 | 
					
						
							|  |  |  | #define G_IS_INPUT_STREAM_CLASS(k)  (G_TYPE_CHECK_CLASS_TYPE ((k), G_TYPE_INPUT_STREAM))
 | 
					
						
							|  |  |  | #define G_INPUT_STREAM_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), G_TYPE_INPUT_STREAM, GInputStreamClass))
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-11-27 14:00:13 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * GInputStream: | 
					
						
							| 
									
										
										
										
											2008-09-02 19:05:58 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2007-11-27 14:00:13 +00:00
										 |  |  |  * Base class for streaming input operations. | 
					
						
							|  |  |  |  **/ | 
					
						
							| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  | typedef struct _GInputStreamClass    GInputStreamClass; | 
					
						
							|  |  |  | typedef struct _GInputStreamPrivate  GInputStreamPrivate; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct _GInputStream | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2007-12-12 14:33:20 +00:00
										 |  |  |   GObject parent_instance; | 
					
						
							| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   /*< private >*/ | 
					
						
							|  |  |  |   GInputStreamPrivate *priv; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct _GInputStreamClass | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   GObjectClass parent_class; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* Sync ops: */ | 
					
						
							| 
									
										
										
										
											2008-09-02 19:05:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   gssize   (* read_fn)      (GInputStream        *stream, | 
					
						
							|  |  |  |                              void                *buffer, | 
					
						
							|  |  |  |                              gsize                count, | 
					
						
							|  |  |  |                              GCancellable        *cancellable, | 
					
						
							|  |  |  |                              GError             **error); | 
					
						
							|  |  |  |   gssize   (* skip)         (GInputStream        *stream, | 
					
						
							|  |  |  |                              gsize                count, | 
					
						
							|  |  |  |                              GCancellable        *cancellable, | 
					
						
							|  |  |  |                              GError             **error); | 
					
						
							|  |  |  |   gboolean (* close_fn)	    (GInputStream        *stream, | 
					
						
							|  |  |  |                              GCancellable        *cancellable, | 
					
						
							|  |  |  |                              GError             **error); | 
					
						
							| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |   /* Async ops: (optional in derived classes) */ | 
					
						
							| 
									
										
										
										
											2008-09-02 19:05:58 +00:00
										 |  |  |   void     (* read_async)   (GInputStream        *stream, | 
					
						
							|  |  |  |                              void                *buffer, | 
					
						
							|  |  |  |                              gsize                count, | 
					
						
							|  |  |  |                              int                  io_priority, | 
					
						
							|  |  |  |                              GCancellable        *cancellable, | 
					
						
							|  |  |  |                              GAsyncReadyCallback  callback, | 
					
						
							|  |  |  |                              gpointer             user_data); | 
					
						
							|  |  |  |   gssize   (* read_finish)  (GInputStream        *stream, | 
					
						
							|  |  |  |                              GAsyncResult        *result, | 
					
						
							|  |  |  |                              GError             **error); | 
					
						
							|  |  |  |   void     (* skip_async)   (GInputStream        *stream, | 
					
						
							|  |  |  |                              gsize                count, | 
					
						
							|  |  |  |                              int                  io_priority, | 
					
						
							|  |  |  |                              GCancellable        *cancellable, | 
					
						
							|  |  |  |                              GAsyncReadyCallback  callback, | 
					
						
							|  |  |  |                              gpointer             user_data); | 
					
						
							|  |  |  |   gssize   (* skip_finish)  (GInputStream        *stream, | 
					
						
							|  |  |  |                              GAsyncResult        *result, | 
					
						
							|  |  |  |                              GError             **error); | 
					
						
							|  |  |  |   void     (* close_async)  (GInputStream        *stream, | 
					
						
							|  |  |  |                              int                  io_priority, | 
					
						
							|  |  |  |                              GCancellable        *cancellable, | 
					
						
							|  |  |  |                              GAsyncReadyCallback  callback, | 
					
						
							|  |  |  |                              gpointer             user_data); | 
					
						
							|  |  |  |   gboolean (* close_finish) (GInputStream        *stream, | 
					
						
							|  |  |  |                              GAsyncResult        *result, | 
					
						
							|  |  |  |                              GError             **error); | 
					
						
							| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-11-27 14:00:13 +00:00
										 |  |  |   /*< private >*/ | 
					
						
							| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  |   /* Padding for future expansion */ | 
					
						
							|  |  |  |   void (*_g_reserved1) (void); | 
					
						
							|  |  |  |   void (*_g_reserved2) (void); | 
					
						
							|  |  |  |   void (*_g_reserved3) (void); | 
					
						
							|  |  |  |   void (*_g_reserved4) (void); | 
					
						
							|  |  |  |   void (*_g_reserved5) (void); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-02 19:05:58 +00:00
										 |  |  | GType    g_input_stream_get_type      (void) G_GNUC_CONST; | 
					
						
							| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-12-04 08:57:04 +00:00
										 |  |  | gssize   g_input_stream_read          (GInputStream          *stream, | 
					
						
							|  |  |  | 				       void                  *buffer, | 
					
						
							|  |  |  | 				       gsize                  count, | 
					
						
							|  |  |  | 				       GCancellable          *cancellable, | 
					
						
							|  |  |  | 				       GError               **error); | 
					
						
							|  |  |  | gboolean g_input_stream_read_all      (GInputStream          *stream, | 
					
						
							|  |  |  | 				       void                  *buffer, | 
					
						
							|  |  |  | 				       gsize                  count, | 
					
						
							|  |  |  | 				       gsize                 *bytes_read, | 
					
						
							|  |  |  | 				       GCancellable          *cancellable, | 
					
						
							|  |  |  | 				       GError               **error); | 
					
						
							| 
									
										
										
										
											2012-04-05 09:19:17 -04:00
										 |  |  | GLIB_AVAILABLE_IN_2_34 | 
					
						
							|  |  |  | GBytes  *g_input_stream_read_bytes    (GInputStream          *stream, | 
					
						
							|  |  |  | 				       gsize                  count, | 
					
						
							|  |  |  | 				       GCancellable          *cancellable, | 
					
						
							|  |  |  | 				       GError               **error); | 
					
						
							| 
									
										
										
										
											2007-12-04 08:57:04 +00:00
										 |  |  | gssize   g_input_stream_skip          (GInputStream          *stream, | 
					
						
							|  |  |  | 				       gsize                  count, | 
					
						
							|  |  |  | 				       GCancellable          *cancellable, | 
					
						
							|  |  |  | 				       GError               **error); | 
					
						
							|  |  |  | gboolean g_input_stream_close         (GInputStream          *stream, | 
					
						
							|  |  |  | 				       GCancellable          *cancellable, | 
					
						
							|  |  |  | 				       GError               **error); | 
					
						
							|  |  |  | void     g_input_stream_read_async    (GInputStream          *stream, | 
					
						
							|  |  |  | 				       void                  *buffer, | 
					
						
							|  |  |  | 				       gsize                  count, | 
					
						
							|  |  |  | 				       int                    io_priority, | 
					
						
							|  |  |  | 				       GCancellable          *cancellable, | 
					
						
							|  |  |  | 				       GAsyncReadyCallback    callback, | 
					
						
							|  |  |  | 				       gpointer               user_data); | 
					
						
							|  |  |  | gssize   g_input_stream_read_finish   (GInputStream          *stream, | 
					
						
							|  |  |  | 				       GAsyncResult          *result, | 
					
						
							|  |  |  | 				       GError               **error); | 
					
						
							| 
									
										
										
										
											2012-04-05 09:19:17 -04:00
										 |  |  | GLIB_AVAILABLE_IN_2_34 | 
					
						
							|  |  |  | void     g_input_stream_read_bytes_async  (GInputStream          *stream, | 
					
						
							|  |  |  | 					   gsize                  count, | 
					
						
							|  |  |  | 					   int                    io_priority, | 
					
						
							|  |  |  | 					   GCancellable          *cancellable, | 
					
						
							|  |  |  | 					   GAsyncReadyCallback    callback, | 
					
						
							|  |  |  | 					   gpointer               user_data); | 
					
						
							|  |  |  | GLIB_AVAILABLE_IN_2_34 | 
					
						
							|  |  |  | GBytes  *g_input_stream_read_bytes_finish (GInputStream          *stream, | 
					
						
							|  |  |  | 					   GAsyncResult          *result, | 
					
						
							|  |  |  | 					   GError               **error); | 
					
						
							| 
									
										
										
										
											2007-12-04 08:57:04 +00:00
										 |  |  | void     g_input_stream_skip_async    (GInputStream          *stream, | 
					
						
							|  |  |  | 				       gsize                  count, | 
					
						
							|  |  |  | 				       int                    io_priority, | 
					
						
							|  |  |  | 				       GCancellable          *cancellable, | 
					
						
							|  |  |  | 				       GAsyncReadyCallback    callback, | 
					
						
							|  |  |  | 				       gpointer               user_data); | 
					
						
							|  |  |  | gssize   g_input_stream_skip_finish   (GInputStream          *stream, | 
					
						
							|  |  |  | 				       GAsyncResult          *result, | 
					
						
							|  |  |  | 				       GError               **error); | 
					
						
							|  |  |  | void     g_input_stream_close_async   (GInputStream          *stream, | 
					
						
							|  |  |  | 				       int                    io_priority, | 
					
						
							|  |  |  | 				       GCancellable          *cancellable, | 
					
						
							|  |  |  | 				       GAsyncReadyCallback    callback, | 
					
						
							|  |  |  | 				       gpointer               user_data); | 
					
						
							|  |  |  | gboolean g_input_stream_close_finish  (GInputStream          *stream, | 
					
						
							|  |  |  | 				       GAsyncResult          *result, | 
					
						
							|  |  |  | 				       GError               **error); | 
					
						
							| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* For implementations: */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-12-04 08:57:04 +00:00
										 |  |  | gboolean g_input_stream_is_closed     (GInputStream          *stream); | 
					
						
							|  |  |  | gboolean g_input_stream_has_pending   (GInputStream          *stream); | 
					
						
							|  |  |  | gboolean g_input_stream_set_pending   (GInputStream          *stream, | 
					
						
							|  |  |  | 				       GError               **error); | 
					
						
							|  |  |  | void     g_input_stream_clear_pending (GInputStream          *stream); | 
					
						
							| 
									
										
										
										
											2007-11-26 16:13:05 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | G_END_DECLS | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* __G_INPUT_STREAM_H__ */
 |