X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=gio%2Fgfileinputstream.c;h=41014d410237b9282d770a1a1def21e698e47854;hb=7fd6f07d498063470903a886b4805a13bd333908;hp=bc5cc70f5ebdb4abb60dcbd8228bc8b052437a8f;hpb=09471fec46619a62fbe9b6e7a7b67c9a421f919e;p=platform%2Fupstream%2Fglib.git diff --git a/gio/gfileinputstream.c b/gio/gfileinputstream.c index bc5cc70..41014d4 100644 --- a/gio/gfileinputstream.c +++ b/gio/gfileinputstream.c @@ -13,30 +13,38 @@ * 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. + * Public License along with this library; if not, see . * * Author: Alexander Larsson */ -#include +#include "config.h" #include #include #include -#include "gsimpleasyncresult.h" +#include "gcancellable.h" +#include "gasyncresult.h" +#include "gtask.h" +#include "gioerror.h" #include "glibintl.h" -#include "gioalias.h" /** * SECTION:gfileinputstream - * @short_description: file input streaming operations + * @short_description: File input streaming operations + * @include: gio/gio.h * @see_also: #GInputStream, #GDataInputStream, #GSeekable - * - * * + * GFileInputStream provides input streams that take their + * content from a file. + * + * GFileInputStream implements #GSeekable, which allows the input + * stream to jump to arbitrary positions in the file, provided the + * filesystem of the file allows it. To find the position of a file + * input stream, use g_seekable_tell(). To find out if a file input + * stream supports seeking, use g_seekable_can_seek(). + * To position a file input stream, use g_seekable_seek(). **/ static void g_file_input_stream_seekable_iface_init (GSeekableIface *iface); @@ -53,7 +61,7 @@ static gboolean g_file_input_stream_seekable_truncate (GSeekable GCancellable *cancellable, GError **error); static void g_file_input_stream_real_query_info_async (GFileInputStream *stream, - char *attributes, + const char *attributes, int io_priority, GCancellable *cancellable, GAsyncReadyCallback callback, @@ -63,19 +71,18 @@ static GFileInfo *g_file_input_stream_real_query_info_finish (GFileInputStream GError **error); -G_DEFINE_TYPE_WITH_CODE (GFileInputStream, g_file_input_stream, G_TYPE_INPUT_STREAM, - G_IMPLEMENT_INTERFACE (G_TYPE_SEEKABLE, - g_file_input_stream_seekable_iface_init)) - struct _GFileInputStreamPrivate { GAsyncReadyCallback outstanding_callback; }; +G_DEFINE_TYPE_WITH_CODE (GFileInputStream, g_file_input_stream, G_TYPE_INPUT_STREAM, + G_ADD_PRIVATE (GFileInputStream) + G_IMPLEMENT_INTERFACE (G_TYPE_SEEKABLE, + g_file_input_stream_seekable_iface_init)) + static void g_file_input_stream_class_init (GFileInputStreamClass *klass) { - g_type_class_add_private (klass, sizeof (GFileInputStreamPrivate)); - klass->query_info_async = g_file_input_stream_real_query_info_async; klass->query_info_finish = g_file_input_stream_real_query_info_finish; } @@ -87,36 +94,34 @@ g_file_input_stream_seekable_iface_init (GSeekableIface *iface) iface->can_seek = g_file_input_stream_seekable_can_seek; iface->seek = g_file_input_stream_seekable_seek; iface->can_truncate = g_file_input_stream_seekable_can_truncate; - iface->truncate = g_file_input_stream_seekable_truncate; + iface->truncate_fn = g_file_input_stream_seekable_truncate; } static void g_file_input_stream_init (GFileInputStream *stream) { - stream->priv = G_TYPE_INSTANCE_GET_PRIVATE (stream, - G_TYPE_FILE_INPUT_STREAM, - GFileInputStreamPrivate); + stream->priv = g_file_input_stream_get_instance_private (stream); } /** * g_file_input_stream_query_info: * @stream: a #GFileInputStream. * @attributes: a file attribute query string. - * @cancellable: optional #GCancellable object, %NULL to ignore. - * @error: a #GError location to store the error occuring, or %NULL to + * @cancellable: (allow-none): optional #GCancellable object, %NULL to ignore. + * @error: a #GError location to store the error occurring, or %NULL to * ignore. * - * Queries a file input stream the given @attributes.his function blocks + * Queries a file input stream the given @attributes. This function blocks * while querying the stream. For the asynchronous (non-blocking) version * of this function, see g_file_input_stream_query_info_async(). While the * stream is blocked, the stream will set the pending flag internally, and * any other operations on the stream will fail with %G_IO_ERROR_PENDING. * - * Returns: a #GFileInfo, or %NULL on error. + * Returns: (transfer full): a #GFileInfo, or %NULL on error. **/ GFileInfo * g_file_input_stream_query_info (GFileInputStream *stream, - char *attributes, + const char *attributes, GCancellable *cancellable, GError **error) { @@ -128,38 +133,25 @@ g_file_input_stream_query_info (GFileInputStream *stream, input_stream = G_INPUT_STREAM (stream); - if (g_input_stream_is_closed (input_stream)) - { - g_set_error (error, G_IO_ERROR, G_IO_ERROR_CLOSED, - _("Stream is already closed")); - return NULL; - } - - if (g_input_stream_has_pending (input_stream)) - { - g_set_error (error, G_IO_ERROR, G_IO_ERROR_PENDING, - _("Stream has outstanding operation")); - return NULL; - } + if (!g_input_stream_set_pending (input_stream, error)) + return NULL; info = NULL; - g_input_stream_set_pending (input_stream, TRUE); - if (cancellable) - g_push_current_cancellable (cancellable); + g_cancellable_push_current (cancellable); class = G_FILE_INPUT_STREAM_GET_CLASS (stream); if (class->query_info) info = class->query_info (stream, attributes, cancellable, error); else - g_set_error (error, G_IO_ERROR, G_IO_ERROR_NOT_SUPPORTED, - _("Stream doesn't support query_info")); + g_set_error_literal (error, G_IO_ERROR, G_IO_ERROR_NOT_SUPPORTED, + _("Stream doesn't support query_info")); if (cancellable) - g_pop_current_cancellable (cancellable); + g_cancellable_pop_current (cancellable); - g_input_stream_set_pending (input_stream, FALSE); + g_input_stream_clear_pending (input_stream); return info; } @@ -171,7 +163,7 @@ async_ready_callback_wrapper (GObject *source_object, { GFileInputStream *stream = G_FILE_INPUT_STREAM (source_object); - g_input_stream_set_pending (G_INPUT_STREAM (stream), FALSE); + g_input_stream_clear_pending (G_INPUT_STREAM (stream)); if (stream->priv->outstanding_callback) (*stream->priv->outstanding_callback) (source_object, res, user_data); g_object_unref (stream); @@ -181,13 +173,18 @@ async_ready_callback_wrapper (GObject *source_object, * g_file_input_stream_query_info_async: * @stream: a #GFileInputStream. * @attributes: a file attribute query string. - * @io_priority: the i/o priority of the request. - * @cancellable: optional #GCancellable object, %NULL to ignore. - * @callback: callback to call when the request is satisfied - * @user_data: the data to pass to callback function + * @io_priority: the [I/O priority][io-priority] of the request + * @cancellable: (allow-none): optional #GCancellable object, %NULL to ignore. + * @callback: (scope async): callback to call when the request is satisfied + * @user_data: (closure): the data to pass to callback function * - * Queries the stream information asynchronously. For the synchronous - * version of this function, see g_file_input_stream_query_info(). + * Queries the stream information asynchronously. + * When the operation is finished @callback will be called. + * You can then call g_file_input_stream_query_info_finish() + * to get the result of the operation. + * + * For the synchronous version of this function, + * see g_file_input_stream_query_info(). * * If @cancellable is not %NULL, then the operation can be cancelled by * triggering the cancellable object from another thread. If the operation @@ -196,7 +193,7 @@ async_ready_callback_wrapper (GObject *source_object, **/ void g_file_input_stream_query_info_async (GFileInputStream *stream, - char *attributes, + const char *attributes, int io_priority, GCancellable *cancellable, GAsyncReadyCallback callback, @@ -204,82 +201,59 @@ g_file_input_stream_query_info_async (GFileInputStream *stream, { GFileInputStreamClass *klass; GInputStream *input_stream; + GError *error = NULL; g_return_if_fail (G_IS_FILE_INPUT_STREAM (stream)); input_stream = G_INPUT_STREAM (stream); - - if (g_input_stream_is_closed (input_stream)) - { - g_simple_async_report_error_in_idle (G_OBJECT (stream), - callback, - user_data, - G_IO_ERROR, G_IO_ERROR_CLOSED, - _("Stream is already closed")); - return; - } - if (g_input_stream_has_pending (input_stream)) + if (!g_input_stream_set_pending (input_stream, &error)) { - g_simple_async_report_error_in_idle (G_OBJECT (stream), - callback, - user_data, - G_IO_ERROR, G_IO_ERROR_PENDING, - _("Stream has outstanding operation")); + g_task_report_error (stream, callback, user_data, + g_file_input_stream_query_info_async, + error); return; } klass = G_FILE_INPUT_STREAM_GET_CLASS (stream); - g_input_stream_set_pending (input_stream, TRUE); stream->priv->outstanding_callback = callback; g_object_ref (stream); klass->query_info_async (stream, attributes, io_priority, cancellable, - async_ready_callback_wrapper, user_data); + async_ready_callback_wrapper, user_data); } /** * g_file_input_stream_query_info_finish: * @stream: a #GFileInputStream. * @result: a #GAsyncResult. - * @error: a #GError location to store the error occuring, + * @error: a #GError location to store the error occurring, * or %NULL to ignore. * * Finishes an asynchronous info query operation. * - * Returns: #GFileInfo. + * Returns: (transfer full): #GFileInfo. **/ GFileInfo * g_file_input_stream_query_info_finish (GFileInputStream *stream, GAsyncResult *result, GError **error) { - GSimpleAsyncResult *simple; GFileInputStreamClass *class; g_return_val_if_fail (G_IS_FILE_INPUT_STREAM (stream), NULL); g_return_val_if_fail (G_IS_ASYNC_RESULT (result), NULL); - if (G_IS_SIMPLE_ASYNC_RESULT (result)) - { - simple = G_SIMPLE_ASYNC_RESULT (result); - if (g_simple_async_result_propagate_error (simple, error)) - return NULL; - } + if (g_async_result_legacy_propagate_error (result, error)) + return NULL; + else if (g_async_result_is_tagged (result, g_file_input_stream_query_info_async)) + return g_task_propagate_pointer (G_TASK (result), error); class = G_FILE_INPUT_STREAM_GET_CLASS (stream); return class->query_info_finish (stream, result, error); } -/** - * g_file_input_stream_tell: - * @stream: a #GFileInputStream. - * - * Gets the current position in the stream. - * - * Returns: a #goffset with the position in the stream. - **/ -goffset +static goffset g_file_input_stream_tell (GFileInputStream *stream) { GFileInputStreamClass *class; @@ -302,15 +276,7 @@ g_file_input_stream_seekable_tell (GSeekable *seekable) return g_file_input_stream_tell (G_FILE_INPUT_STREAM (seekable)); } -/** - * g_file_input_stream_can_seek: - * @stream: a #GFileInputStream. - * - * Checks if a file input stream can be seeked. - * - * Returns: %TRUE if stream can be seeked. %FALSE otherwise. - **/ -gboolean +static gboolean g_file_input_stream_can_seek (GFileInputStream *stream) { GFileInputStreamClass *class; @@ -337,25 +303,7 @@ g_file_input_stream_seekable_can_seek (GSeekable *seekable) return g_file_input_stream_can_seek (G_FILE_INPUT_STREAM (seekable)); } -/** - * g_file_input_stream_seek: - * @stream: a #GFileInputStream. - * @offset: a #goffset to seek. - * @type: a #GSeekType. - * @cancellable: optional #GCancellable object, %NULL to ignore. - * @error: a #GError location to store the error occuring, or - * %NULL to ignore. - * - * Seeks in the file input stream. - * - * If @cancellable is not %NULL, then the operation can be cancelled by - * triggering the cancellable object from another thread. If the operation - * was cancelled, the error %G_IO_ERROR_CANCELLED will be set. - * - * Returns: %TRUE if the stream was successfully seeked to the position. - * %FALSE on error. - **/ -gboolean +static gboolean g_file_input_stream_seek (GFileInputStream *stream, goffset offset, GSeekType type, @@ -371,38 +319,25 @@ g_file_input_stream_seek (GFileInputStream *stream, input_stream = G_INPUT_STREAM (stream); class = G_FILE_INPUT_STREAM_GET_CLASS (stream); - if (g_input_stream_is_closed (input_stream)) - { - g_set_error (error, G_IO_ERROR, G_IO_ERROR_CLOSED, - _("Stream is already closed")); - return FALSE; - } - - if (g_input_stream_has_pending (input_stream)) - { - g_set_error (error, G_IO_ERROR, G_IO_ERROR_PENDING, - _("Stream has outstanding operation")); - return FALSE; - } - if (!class->seek) { - g_set_error (error, G_IO_ERROR, G_IO_ERROR_NOT_SUPPORTED, - _("Seek not supported on stream")); + g_set_error_literal (error, G_IO_ERROR, G_IO_ERROR_NOT_SUPPORTED, + _("Seek not supported on stream")); return FALSE; } - g_input_stream_set_pending (input_stream, TRUE); + if (!g_input_stream_set_pending (input_stream, error)) + return FALSE; if (cancellable) - g_push_current_cancellable (cancellable); + g_cancellable_push_current (cancellable); res = class->seek (stream, offset, type, cancellable, error); if (cancellable) - g_pop_current_cancellable (cancellable); + g_cancellable_pop_current (cancellable); - g_input_stream_set_pending (input_stream, FALSE); + g_input_stream_clear_pending (input_stream); return res; } @@ -430,8 +365,8 @@ g_file_input_stream_seekable_truncate (GSeekable *seekable, GCancellable *cancellable, GError **error) { - g_set_error (error, G_IO_ERROR, G_IO_ERROR_NOT_SUPPORTED, - _("Truncate not allowed on input stream")); + g_set_error_literal (error, G_IO_ERROR, G_IO_ERROR_NOT_SUPPORTED, + _("Truncate not allowed on input stream")); return FALSE; } @@ -439,69 +374,47 @@ g_file_input_stream_seekable_truncate (GSeekable *seekable, * Default implementation of async ops * ********************************************/ -typedef struct { - char *attributes; - GFileInfo *info; -} QueryInfoAsyncData; - static void -query_info_data_free (QueryInfoAsyncData *data) -{ - if (data->info) - g_object_unref (data->info); - g_free (data->attributes); - g_free (data); -} - -static void -query_info_async_thread (GSimpleAsyncResult *res, - GObject *object, - GCancellable *cancellable) +query_info_async_thread (GTask *task, + gpointer source_object, + gpointer task_data, + GCancellable *cancellable) { + GFileInputStream *stream = source_object; + const char *attributes = task_data; GFileInputStreamClass *class; GError *error = NULL; - QueryInfoAsyncData *data; - GFileInfo *info; - - data = g_simple_async_result_get_op_res_gpointer (res); + GFileInfo *info = NULL; - info = NULL; - - class = G_FILE_INPUT_STREAM_GET_CLASS (object); + class = G_FILE_INPUT_STREAM_GET_CLASS (stream); if (class->query_info) - info = class->query_info (G_FILE_INPUT_STREAM (object), data->attributes, cancellable, &error); + info = class->query_info (stream, attributes, cancellable, &error); else - g_set_error (&error, G_IO_ERROR, G_IO_ERROR_NOT_SUPPORTED, - _("Stream doesn't support query_info")); + g_set_error_literal (&error, G_IO_ERROR, G_IO_ERROR_NOT_SUPPORTED, + _("Stream doesn't support query_info")); if (info == NULL) - { - g_simple_async_result_set_from_error (res, error); - g_error_free (error); - } + g_task_return_error (task, error); else - data->info = info; + g_task_return_pointer (task, info, g_object_unref); } static void g_file_input_stream_real_query_info_async (GFileInputStream *stream, - char *attributes, + const char *attributes, int io_priority, GCancellable *cancellable, GAsyncReadyCallback callback, gpointer user_data) { - GSimpleAsyncResult *res; - QueryInfoAsyncData *data; + GTask *task; - data = g_new0 (QueryInfoAsyncData, 1); - data->attributes = g_strdup (attributes); - - res = g_simple_async_result_new (G_OBJECT (stream), callback, user_data, g_file_input_stream_real_query_info_async); - g_simple_async_result_set_op_res_gpointer (res, data, (GDestroyNotify)query_info_data_free); + task = g_task_new (stream, cancellable, callback, user_data); + g_task_set_task_data (task, g_strdup (attributes), g_free); + g_task_set_priority (task, io_priority); - g_simple_async_result_run_in_thread (res, query_info_async_thread, io_priority, cancellable); - g_object_unref (res); + g_task_run_in_thread (task, query_info_async_thread); + g_object_unref (task); } static GFileInfo * @@ -509,18 +422,7 @@ g_file_input_stream_real_query_info_finish (GFileInputStream *stream, GAsyncResult *res, GError **error) { - GSimpleAsyncResult *simple = G_SIMPLE_ASYNC_RESULT (res); - QueryInfoAsyncData *data; + g_return_val_if_fail (g_task_is_valid (res, stream), NULL); - g_assert (g_simple_async_result_get_source_tag (simple) == g_file_input_stream_real_query_info_async); - - data = g_simple_async_result_get_op_res_gpointer (simple); - if (data->info) - return g_object_ref (data->info); - - return NULL; + return g_task_propagate_pointer (G_TASK (res), error); } - -#define __G_FILE_INPUT_STREAM_C__ -#include "gioaliasdef.c" -