[latexila/wip/latexila-next: 1/2] PostProcessor: show/hide details
- From: Sébastien Wilmet <swilmet src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [latexila/wip/latexila-next: 1/2] PostProcessor: show/hide details
- Date: Tue, 30 Sep 2014 13:09:04 +0000 (UTC)
commit f28aea3e4b9f58dc2d8cf1f4b753e361b85787f1
Author: Sébastien Wilmet <swilmet gnome org>
Date: Tue Sep 30 13:08:09 2014 +0200
PostProcessor: show/hide details
src/liblatexila/latexila-build-job.c | 57 ++++++++++++++++----
.../latexila-post-processor-all-output.c | 3 +-
src/liblatexila/latexila-post-processor-latex.c | 3 +-
src/liblatexila/latexila-post-processor-latexmk.c | 13 ++++-
src/liblatexila/latexila-post-processor.c | 38 ++++---------
src/liblatexila/latexila-post-processor.h | 6 ++-
6 files changed, 78 insertions(+), 42 deletions(-)
---
diff --git a/src/liblatexila/latexila-build-job.c b/src/liblatexila/latexila-build-job.c
index 78f3664..7d7a424 100644
--- a/src/liblatexila/latexila-build-job.c
+++ b/src/liblatexila/latexila-build-job.c
@@ -116,8 +116,8 @@ latexila_build_job_dispose (GObject *object)
g_clear_object (&build_job->priv->task);
g_clear_object (&build_job->priv->file);
- g_clear_object (&build_job->priv->build_view);
- g_clear_object (&build_job->priv->post_processor);
+
+ latexila_build_job_clear (build_job);
G_OBJECT_CLASS (latexila_build_job_parent_class)->dispose (object);
}
@@ -387,23 +387,54 @@ display_command_line (LatexilaBuildJob *build_job)
}
static void
-post_processor_cb (LatexilaPostProcessor *pp,
- GAsyncResult *result,
- LatexilaBuildJob *build_job)
+show_details_notify_cb (LatexilaBuildView *build_view,
+ GParamSpec *pspec,
+ LatexilaBuildJob *build_job)
{
const GQueue *messages;
+ gboolean show_details;
- latexila_post_processor_process_finish (pp, result);
+ latexila_build_view_remove_children (build_view,
+ &build_job->priv->job_title);
- messages = latexila_post_processor_get_messages (pp);
+ g_object_get (build_view, "show-details", &show_details, NULL);
- latexila_build_view_append_messages (build_job->priv->build_view,
+ messages = latexila_post_processor_get_messages (build_job->priv->post_processor,
+ show_details);
+
+ latexila_build_view_append_messages (build_view,
&build_job->priv->job_title,
messages,
TRUE);
}
static void
+post_processor_cb (LatexilaPostProcessor *pp,
+ GAsyncResult *result,
+ LatexilaBuildJob *build_job)
+{
+ gboolean has_details;
+
+ latexila_post_processor_process_finish (pp, result);
+
+ g_object_get (pp, "has-details", &has_details, NULL);
+
+ if (has_details)
+ g_object_set (build_job->priv->build_view,
+ "has-details", TRUE,
+ NULL);
+
+ g_signal_connect (build_job->priv->build_view,
+ "notify::show-details",
+ G_CALLBACK (show_details_notify_cb),
+ build_job);
+
+ show_details_notify_cb (build_job->priv->build_view,
+ NULL,
+ build_job);
+}
+
+static void
subprocess_wait_cb (GSubprocess *subprocess,
GAsyncResult *result,
LatexilaBuildJob *build_job)
@@ -547,10 +578,9 @@ latexila_build_job_run_async (LatexilaBuildJob *build_job,
g_clear_object (&build_job->priv->file);
build_job->priv->file = g_object_ref (file);
- g_clear_object (&build_job->priv->build_view);
- build_job->priv->build_view = g_object_ref (build_view);
+ latexila_build_job_clear (build_job);
- g_clear_object (&build_job->priv->post_processor);
+ build_job->priv->build_view = g_object_ref (build_view);
if (!display_command_line (build_job))
{
@@ -610,6 +640,11 @@ latexila_build_job_run_finish (LatexilaBuildJob *build_job,
void
latexila_build_job_clear (LatexilaBuildJob *build_job)
{
+ if (build_job->priv->build_view != NULL)
+ g_signal_handlers_disconnect_by_func (build_job->priv->build_view,
+ show_details_notify_cb,
+ build_job);
+
g_clear_object (&build_job->priv->build_view);
g_clear_object (&build_job->priv->post_processor);
}
diff --git a/src/liblatexila/latexila-post-processor-all-output.c
b/src/liblatexila/latexila-post-processor-all-output.c
index 942bcbb..b2107ac 100644
--- a/src/liblatexila/latexila-post-processor-all-output.c
+++ b/src/liblatexila/latexila-post-processor-all-output.c
@@ -56,7 +56,8 @@ latexila_post_processor_all_output_process_line (LatexilaPostProcessor *post_pro
}
static const GQueue *
-latexila_post_processor_all_output_get_messages (LatexilaPostProcessor *post_processor)
+latexila_post_processor_all_output_get_messages (LatexilaPostProcessor *post_processor,
+ gboolean show_details)
{
LatexilaPostProcessorAllOutput *pp = LATEXILA_POST_PROCESSOR_ALL_OUTPUT (post_processor);
diff --git a/src/liblatexila/latexila-post-processor-latex.c b/src/liblatexila/latexila-post-processor-latex.c
index f795a23..3c4eb25 100644
--- a/src/liblatexila/latexila-post-processor-latex.c
+++ b/src/liblatexila/latexila-post-processor-latex.c
@@ -1363,7 +1363,8 @@ latexila_post_processor_latex_process_line (LatexilaPostProcessor *post_processo
}
static const GQueue *
-latexila_post_processor_latex_get_messages (LatexilaPostProcessor *post_processor)
+latexila_post_processor_latex_get_messages (LatexilaPostProcessor *post_processor,
+ gboolean show_details)
{
LatexilaPostProcessorLatex *pp = LATEXILA_POST_PROCESSOR_LATEX (post_processor);
diff --git a/src/liblatexila/latexila-post-processor-latexmk.c
b/src/liblatexila/latexila-post-processor-latexmk.c
index 806117d..56181eb 100644
--- a/src/liblatexila/latexila-post-processor-latexmk.c
+++ b/src/liblatexila/latexila-post-processor-latexmk.c
@@ -590,9 +590,20 @@ latexila_post_processor_latexmk_end (LatexilaPostProcessor *post_processor)
}
static const GQueue *
-latexila_post_processor_latexmk_get_messages (LatexilaPostProcessor *post_processor)
+latexila_post_processor_latexmk_get_messages (LatexilaPostProcessor *post_processor,
+ gboolean show_details)
{
LatexilaPostProcessorLatexmk *pp = LATEXILA_POST_PROCESSOR_LATEXMK (post_processor);
+ gboolean has_details;
+
+ g_object_get (pp, "has-details", &has_details, NULL);
+
+ if (has_details && !show_details)
+ {
+ /* TODO don't display the command line */
+ g_assert (pp->priv->last_latex_sub_command != NULL);
+ return pp->priv->last_latex_sub_command->children;
+ }
return pp->priv->messages;
}
diff --git a/src/liblatexila/latexila-post-processor.c b/src/liblatexila/latexila-post-processor.c
index 4ac8516..5f4daf5 100644
--- a/src/liblatexila/latexila-post-processor.c
+++ b/src/liblatexila/latexila-post-processor.c
@@ -56,14 +56,12 @@ struct _LatexilaPostProcessorPrivate
GString *line_buffer;
guint has_details : 1;
- guint show_details : 1;
};
enum
{
PROP_0,
- PROP_HAS_DETAILS,
- PROP_SHOW_DETAILS
+ PROP_HAS_DETAILS
};
G_DEFINE_TYPE_WITH_PRIVATE (LatexilaPostProcessor, latexila_post_processor, G_TYPE_OBJECT)
@@ -153,10 +151,6 @@ latexila_post_processor_get_property (GObject *object,
g_value_set_boolean (value, pp->priv->has_details);
break;
- case PROP_SHOW_DETAILS:
- g_value_set_boolean (value, pp->priv->show_details);
- break;
-
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
break;
@@ -177,10 +171,6 @@ latexila_post_processor_set_property (GObject *object,
pp->priv->has_details = g_value_get_boolean (value);
break;
- case PROP_SHOW_DETAILS:
- pp->priv->show_details = g_value_get_boolean (value);
- break;
-
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
break;
@@ -233,7 +223,8 @@ latexila_post_processor_end_default (LatexilaPostProcessor *pp)
}
static const GQueue *
-latexila_post_processor_get_messages_default (LatexilaPostProcessor *pp)
+latexila_post_processor_get_messages_default (LatexilaPostProcessor *pp,
+ gboolean show_details)
{
return NULL;
}
@@ -269,16 +260,6 @@ latexila_post_processor_class_init (LatexilaPostProcessorClass *klass)
G_PARAM_READWRITE |
G_PARAM_CONSTRUCT |
G_PARAM_STATIC_STRINGS));
-
- g_object_class_install_property (object_class,
- PROP_SHOW_DETAILS,
- g_param_spec_boolean ("show-details",
- "Show details",
- "",
- FALSE,
- G_PARAM_READWRITE |
- G_PARAM_CONSTRUCT |
- G_PARAM_STATIC_STRINGS));
}
static void
@@ -536,6 +517,8 @@ latexila_post_processor_end (LatexilaPostProcessor *pp)
/**
* latexila_post_processor_get_messages:
* @pp: a post-processor.
+ * @show_details: whether to show the details. Has no effect if
+ * #LatexilaPostProcessor:has-details is %FALSE.
*
* Gets the filtered messages. Call this function only after calling
* latexila_post_processor_process_finish() or latexila_post_processor_end().
@@ -563,19 +546,22 @@ latexila_post_processor_end (LatexilaPostProcessor *pp)
* Element types: #LatexilaBuildMsg.
*/
const GQueue *
-latexila_post_processor_get_messages (LatexilaPostProcessor *pp)
+latexila_post_processor_get_messages (LatexilaPostProcessor *pp,
+ gboolean show_details)
{
g_return_val_if_fail (LATEXILA_IS_POST_PROCESSOR (pp), NULL);
- return LATEXILA_POST_PROCESSOR_GET_CLASS (pp)->get_messages (pp);
+ show_details = show_details != FALSE;
+
+ return LATEXILA_POST_PROCESSOR_GET_CLASS (pp)->get_messages (pp, show_details);
}
/**
* latexila_post_processor_take_messages: (skip)
* @pp: a #LatexilaPostProcessor.
*
- * Takes ownership of the messages. Since #GQueue is not reference counted, @pp
- * is emptied and is thus useless after calling this function.
+ * Takes ownership of all the messages. Since #GQueue is not reference counted,
+ * @pp is emptied and is thus useless after calling this function.
*
* Returns: (transfer full) (nullable): the tree of filtered messages, or %NULL.
* Element types: #LatexilaBuildMsg.
diff --git a/src/liblatexila/latexila-post-processor.h b/src/liblatexila/latexila-post-processor.h
index 269bddc..8d98bd3 100644
--- a/src/liblatexila/latexila-post-processor.h
+++ b/src/liblatexila/latexila-post-processor.h
@@ -73,7 +73,8 @@ struct _LatexilaPostProcessorClass
void (* end) (LatexilaPostProcessor *pp);
- const GQueue * (* get_messages) (LatexilaPostProcessor *pp);
+ const GQueue * (* get_messages) (LatexilaPostProcessor *pp,
+ gboolean show_details);
GQueue * (* take_messages) (LatexilaPostProcessor *pp);
};
@@ -103,7 +104,8 @@ void latexila_post_processor_process_line (LatexilaP
void latexila_post_processor_end (LatexilaPostProcessor *pp);
-const GQueue * latexila_post_processor_get_messages (LatexilaPostProcessor *pp);
+const GQueue * latexila_post_processor_get_messages (LatexilaPostProcessor *pp,
+ gboolean show_details);
GQueue * latexila_post_processor_take_messages (LatexilaPostProcessor *pp);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]