[gtksourceview/wip/loader-saver: 9/28] Some code improvements
- From: Sébastien Wilmet <swilmet src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtksourceview/wip/loader-saver: 9/28] Some code improvements
- Date: Sun, 6 Jul 2014 16:40:55 +0000 (UTC)
commit c222e175dd11ae9f963bf94b94a14ed0c65ab02f
Author: Sébastien Wilmet <swilmet gnome org>
Date: Wed Jun 4 22:24:58 2014 +0200
Some code improvements
gtksourceview/gtksourcebufferinputstream.c | 4 +-
gtksourceview/gtksourcebufferinputstream.h | 3 +-
gtksourceview/gtksourcebufferoutputstream.c | 4 +-
gtksourceview/gtksourcebufferoutputstream.h | 3 +-
gtksourceview/gtksourcefileloader.c | 29 ++++++++++---------------
gtksourceview/gtksourcefilesaver.c | 21 +++++++++---------
tests/test-buffer-input-stream.c | 6 ++--
tests/test-buffer-output-stream.c | 30 +++++++++++++-------------
8 files changed, 48 insertions(+), 52 deletions(-)
---
diff --git a/gtksourceview/gtksourcebufferinputstream.c b/gtksourceview/gtksourcebufferinputstream.c
index 8a7fcbf..7f4fc50 100644
--- a/gtksourceview/gtksourcebufferinputstream.c
+++ b/gtksourceview/gtksourcebufferinputstream.c
@@ -450,9 +450,9 @@ _gtk_source_buffer_input_stream_init (GtkSourceBufferInputStream *stream)
*
* Reads the data from @buffer.
*
- * Returns: a new #GInputStream to read @buffer
+ * Returns: a new input stream to read @buffer
*/
-GInputStream *
+GtkSourceBufferInputStream *
_gtk_source_buffer_input_stream_new (GtkTextBuffer *buffer,
GtkSourceNewlineType type,
gboolean add_trailing_newline)
diff --git a/gtksourceview/gtksourcebufferinputstream.h b/gtksourceview/gtksourcebufferinputstream.h
index b80c7c4..97c460b 100644
--- a/gtksourceview/gtksourcebufferinputstream.h
+++ b/gtksourceview/gtksourcebufferinputstream.h
@@ -56,7 +56,8 @@ G_GNUC_INTERNAL
GType _gtk_source_buffer_input_stream_get_type (void) G_GNUC_CONST;
G_GNUC_INTERNAL
-GInputStream *_gtk_source_buffer_input_stream_new (GtkTextBuffer *buffer,
+GtkSourceBufferInputStream
+ *_gtk_source_buffer_input_stream_new (GtkTextBuffer *buffer,
GtkSourceNewlineType type,
gboolean
add_trailing_newline);
diff --git a/gtksourceview/gtksourcebufferoutputstream.c b/gtksourceview/gtksourcebufferoutputstream.c
index b4e4f77..883238f 100644
--- a/gtksourceview/gtksourcebufferoutputstream.c
+++ b/gtksourceview/gtksourcebufferoutputstream.c
@@ -470,7 +470,7 @@ get_newline_type (GtkTextIter *end)
return res;
}
-GOutputStream *
+GtkSourceBufferOutputStream *
gtk_source_buffer_output_stream_new (GtkSourceBuffer *buffer,
GSList *candidate_encodings,
gboolean remove_trailing_newline)
@@ -484,7 +484,7 @@ gtk_source_buffer_output_stream_new (GtkSourceBuffer *buffer,
stream->priv->encodings = g_slist_copy (candidate_encodings);
- return G_OUTPUT_STREAM (stream);
+ return stream;
}
GtkSourceNewlineType
diff --git a/gtksourceview/gtksourcebufferoutputstream.h b/gtksourceview/gtksourcebufferoutputstream.h
index 62b2f5c..041c25e 100644
--- a/gtksourceview/gtksourcebufferoutputstream.h
+++ b/gtksourceview/gtksourcebufferoutputstream.h
@@ -56,7 +56,8 @@ G_GNUC_INTERNAL
GType gtk_source_buffer_output_stream_get_type (void) G_GNUC_CONST;
G_GNUC_INTERNAL
-GOutputStream *gtk_source_buffer_output_stream_new (GtkSourceBuffer *buffer,
+GtkSourceBufferOutputStream
+ *gtk_source_buffer_output_stream_new (GtkSourceBuffer *buffer,
GSList
*candidate_encodings,
gboolean
remove_trailing_newline);
diff --git a/gtksourceview/gtksourcefileloader.c b/gtksourceview/gtksourcefileloader.c
index d4426ca..de10f74 100644
--- a/gtksourceview/gtksourcefileloader.c
+++ b/gtksourceview/gtksourcefileloader.c
@@ -95,15 +95,16 @@ struct _GtkSourceFileLoaderPrivate
GFileProgressCallback progress_cb;
gpointer progress_cb_data;
- /* FIXME is it not better to allocate this field separately? I think the
- * private struct is allocated with GSlice by GObject, and GSlice is
- * better to use only for small struct, no?
- */
gchar chunk_buffer[READ_CHUNK_SIZE];
gssize chunk_bytes_read;
+ /* The two streams cannot be spliced directly, because
+ * (1) we need to call the progress callback
+ * (2) sync methods must be used for the output stream, and async
+ * methods for the input stream.
+ */
GInputStream *input_stream;
- GOutputStream *output_stream;
+ GtkSourceBufferOutputStream *output_stream;
guint guess_content_type_from_content : 1;
guint tried_mount : 1;
@@ -315,7 +316,6 @@ close_input_stream_cb (GInputStream *input_stream,
GtkSourceFileLoader *loader)
{
GError *error = NULL;
- GtkSourceBufferOutputStream *output_stream;
DEBUG ({
g_print ("%s\n", G_STRFUNC);
@@ -337,7 +337,7 @@ close_input_stream_cb (GInputStream *input_stream,
g_print ("Close output stream\n");
});
- g_output_stream_close (loader->priv->output_stream,
+ g_output_stream_close (G_OUTPUT_STREAM (loader->priv->output_stream),
g_task_get_cancellable (loader->priv->task),
&error);
@@ -350,8 +350,7 @@ close_input_stream_cb (GInputStream *input_stream,
/* Check if we needed some fallback char, if so, check if there was a
* previous error and if not set a fallback used error.
*/
- output_stream = GTK_SOURCE_BUFFER_OUTPUT_STREAM (loader->priv->output_stream);
- if (gtk_source_buffer_output_stream_get_num_fallbacks (output_stream) > 0)
+ if (gtk_source_buffer_output_stream_get_num_fallbacks (loader->priv->output_stream) > 0)
{
g_task_return_new_error (loader->priv->task,
GTK_SOURCE_FILE_LOADER_ERROR,
@@ -387,7 +386,7 @@ write_file_chunk (GtkSourceFileLoader *loader)
/* We use sync methods on the buffer stream since it is in memory. Using
* async would be racy and we can end up with invalidated iters.
*/
- bytes_written = g_output_stream_write (loader->priv->output_stream,
+ bytes_written = g_output_stream_write (G_OUTPUT_STREAM (loader->priv->output_stream),
loader->priv->chunk_buffer + chunk_bytes_written,
loader->priv->chunk_bytes_read - chunk_bytes_written,
g_task_get_cancellable (loader->priv->task),
@@ -479,18 +478,14 @@ read_cb (GInputStream *input_stream,
/* End of the file, we are done! */
if (loader->priv->chunk_bytes_read == 0)
{
- GtkSourceBufferOutputStream *output_stream;
-
- output_stream = GTK_SOURCE_BUFFER_OUTPUT_STREAM (loader->priv->output_stream);
-
/* Flush the stream to ensure proper line ending detection. */
- g_output_stream_flush (loader->priv->output_stream, NULL, NULL);
+ g_output_stream_flush (G_OUTPUT_STREAM (loader->priv->output_stream), NULL, NULL);
loader->priv->auto_detected_encoding =
- gtk_source_buffer_output_stream_get_guessed (output_stream);
+ gtk_source_buffer_output_stream_get_guessed (loader->priv->output_stream);
loader->priv->auto_detected_newline_type =
- gtk_source_buffer_output_stream_detect_newline_type (output_stream);
+ gtk_source_buffer_output_stream_detect_newline_type (loader->priv->output_stream);
write_complete (loader);
return;
diff --git a/gtksourceview/gtksourcefilesaver.c b/gtksourceview/gtksourcefilesaver.c
index ed76217..e89fbe2 100644
--- a/gtksourceview/gtksourcefilesaver.c
+++ b/gtksourceview/gtksourcefilesaver.c
@@ -104,11 +104,14 @@ struct _GtkSourceFileSaverPrivate
gssize chunk_bytes_written;
/* The output_stream contains the required converter(s) for the encoding
- * and the compression type. The input_stream is the
- * GtkSourceBufferInputStream (thus in UTF-8, without compression).
+ * and the compression type.
+ * The two streams cannot be spliced directly, because
+ * (1) we need to call the progress callback
+ * (2) sync methods must be used for the input stream, and async
+ * methods for the output stream.
*/
GOutputStream *output_stream;
- GInputStream *input_stream;
+ GtkSourceBufferInputStream *input_stream;
GFileInfo *info;
@@ -550,7 +553,7 @@ write_complete (GtkSourceFileSaver *saver)
g_print ("Close input stream\n");
});
- g_input_stream_close (saver->priv->input_stream,
+ g_input_stream_close (G_INPUT_STREAM (saver->priv->input_stream),
g_task_get_cancellable (saver->priv->task),
&error);
@@ -616,11 +619,9 @@ write_file_chunk_cb (GOutputStream *output_stream,
if (saver->priv->progress_cb != NULL)
{
- GtkSourceBufferInputStream *buffer_stream;
gsize total_chars_written;
- buffer_stream = GTK_SOURCE_BUFFER_INPUT_STREAM (saver->priv->input_stream);
- total_chars_written = _gtk_source_buffer_input_stream_tell (buffer_stream);
+ total_chars_written = _gtk_source_buffer_input_stream_tell (saver->priv->input_stream);
saver->priv->progress_cb (total_chars_written,
saver->priv->total_size,
@@ -663,7 +664,7 @@ read_file_chunk (GtkSourceFileSaver *saver)
/* We use sync methods on doc stream since it is in memory. Using async
* would be racy and we can end up with invalid iters.
*/
- saver->priv->chunk_bytes_read = g_input_stream_read (saver->priv->input_stream,
+ saver->priv->chunk_bytes_read = g_input_stream_read (G_INPUT_STREAM (saver->priv->input_stream),
saver->priv->chunk_buffer,
WRITE_CHUNK_SIZE,
g_task_get_cancellable (saver->priv->task),
@@ -693,7 +694,6 @@ replace_file_cb (GFile *file,
{
GFileOutputStream *file_output_stream;
GOutputStream *output_stream;
- GtkSourceBufferInputStream *buffer_stream;
GError *error = NULL;
DEBUG ({
@@ -768,8 +768,7 @@ replace_file_cb (GFile *file,
saver->priv->output_stream = G_OUTPUT_STREAM (output_stream);
}
- buffer_stream = GTK_SOURCE_BUFFER_INPUT_STREAM (saver->priv->input_stream);
- saver->priv->total_size = _gtk_source_buffer_input_stream_get_total_size (buffer_stream);
+ saver->priv->total_size = _gtk_source_buffer_input_stream_get_total_size (saver->priv->input_stream);
DEBUG ({
g_print ("Total number of characters: %" G_GINT64_FORMAT "\n", saver->priv->total_size);
diff --git a/tests/test-buffer-input-stream.c b/tests/test-buffer-input-stream.c
index 4f71466..218327e 100644
--- a/tests/test-buffer-input-stream.c
+++ b/tests/test-buffer-input-stream.c
@@ -32,7 +32,7 @@ test_consecutive_read (const gchar *inbuf,
gsize read_chunk_len)
{
GtkTextBuffer *buf;
- GInputStream *in;
+ GtkSourceBufferInputStream *in;
gsize outlen;
gssize n, r;
GError *err = NULL;
@@ -50,7 +50,7 @@ test_consecutive_read (const gchar *inbuf,
do
{
- r = g_input_stream_read (in, b + n, read_chunk_len, NULL, &err);
+ r = g_input_stream_read (G_INPUT_STREAM (in), b + n, read_chunk_len, NULL, &err);
g_assert_cmpint (r, >=, 0);
g_assert_no_error (err);
@@ -63,7 +63,7 @@ test_consecutive_read (const gchar *inbuf,
g_assert_cmpstr (b, ==, outbuf);
- close = g_input_stream_close (in, NULL, &err);
+ close = g_input_stream_close (G_INPUT_STREAM (in), NULL, &err);
g_assert (close);
g_assert_no_error (err);
diff --git a/tests/test-buffer-output-stream.c b/tests/test-buffer-output-stream.c
index 7227581..97e72c3 100644
--- a/tests/test-buffer-output-stream.c
+++ b/tests/test-buffer-output-stream.c
@@ -34,7 +34,7 @@ test_consecutive_write (const gchar *inbuf,
GtkSourceNewlineType newline_type)
{
GtkSourceBuffer *source_buffer;
- GOutputStream *out;
+ GtkSourceBufferOutputStream *out;
gsize len;
gssize n, w;
GError *err = NULL;
@@ -51,21 +51,21 @@ test_consecutive_write (const gchar *inbuf,
do
{
len = MIN (write_chunk_len, strlen (inbuf + n));
- w = g_output_stream_write (out, inbuf + n, len, NULL, &err);
+ w = g_output_stream_write (G_OUTPUT_STREAM (out), inbuf + n, len, NULL, &err);
g_assert_cmpint (w, >=, 0);
g_assert_no_error (err);
n += w;
} while (w != 0);
- g_output_stream_flush (out, NULL, &err);
+ g_output_stream_flush (G_OUTPUT_STREAM (out), NULL, &err);
g_assert_no_error (err);
- type = gtk_source_buffer_output_stream_detect_newline_type (GTK_SOURCE_BUFFER_OUTPUT_STREAM (out));
+ type = gtk_source_buffer_output_stream_detect_newline_type (out);
g_assert (type == newline_type);
- g_output_stream_close (out, NULL, &err);
+ g_output_stream_close (G_OUTPUT_STREAM (out), NULL, &err);
g_assert_no_error (err);
g_object_get (G_OBJECT (source_buffer), "text", &b, NULL);
@@ -121,7 +121,7 @@ static void
test_boundary (void)
{
GtkSourceBuffer *source_buffer;
- GOutputStream *out;
+ GtkSourceBufferOutputStream *out;
gint line_count;
GError *err = NULL;
GSList *encodings = NULL;
@@ -130,17 +130,17 @@ test_boundary (void)
encodings = g_slist_prepend (encodings, (gpointer)gtk_source_encoding_get_utf8 ());
out = gtk_source_buffer_output_stream_new (source_buffer, encodings, TRUE);
- g_output_stream_write (out, "\r", 1, NULL, NULL);
- g_output_stream_write (out, "\n", 1, NULL, NULL);
+ g_output_stream_write (G_OUTPUT_STREAM (out), "\r", 1, NULL, NULL);
+ g_output_stream_write (G_OUTPUT_STREAM (out), "\n", 1, NULL, NULL);
- g_output_stream_flush (out, NULL, &err);
+ g_output_stream_flush (G_OUTPUT_STREAM (out), NULL, &err);
g_assert_no_error (err);
line_count = gtk_text_buffer_get_line_count (GTK_TEXT_BUFFER (source_buffer));
g_assert_cmpint (line_count, ==, 2);
- g_output_stream_close (out, NULL, &err);
+ g_output_stream_close (G_OUTPUT_STREAM (out), NULL, &err);
g_assert_no_error (err);
g_object_unref (source_buffer);
@@ -248,7 +248,7 @@ do_test (const gchar *inbuf,
const GtkSourceEncoding **guessed)
{
GtkSourceBuffer *source_buffer;
- GOutputStream *out;
+ GtkSourceBufferOutputStream *out;
GError *err = NULL;
GtkTextIter start, end;
gchar *text;
@@ -269,7 +269,7 @@ do_test (const gchar *inbuf,
do
{
to_write = MIN (len, write_chunk_len);
- w = g_output_stream_write (out, inbuf + n, to_write, NULL, &err);
+ w = g_output_stream_write (G_OUTPUT_STREAM (out), inbuf + n, to_write, NULL, &err);
g_assert_cmpint (w, >=, 0);
g_assert_no_error (err);
@@ -277,15 +277,15 @@ do_test (const gchar *inbuf,
n += w;
} while (len != 0);
- g_output_stream_flush (out, NULL, &err);
+ g_output_stream_flush (G_OUTPUT_STREAM (out), NULL, &err);
g_assert_no_error (err);
- g_output_stream_close (out, NULL, &err);
+ g_output_stream_close (G_OUTPUT_STREAM (out), NULL, &err);
g_assert_no_error (err);
if (guessed != NULL)
{
- *guessed = gtk_source_buffer_output_stream_get_guessed (GTK_SOURCE_BUFFER_OUTPUT_STREAM
(out));
+ *guessed = gtk_source_buffer_output_stream_get_guessed (out);
}
gtk_text_buffer_get_bounds (GTK_TEXT_BUFFER (source_buffer), &start, &end);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]