[pinpoint/wip/speaker-view: 1/3] add parsing of speaker notes
- From: Øyvind Kolås <ok src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [pinpoint/wip/speaker-view: 1/3] add parsing of speaker notes
- Date: Wed, 25 May 2011 16:12:40 +0000 (UTC)
commit 8c717f4e5267d34e40e51d12b51737435334a2d8
Author: �yvind Kolås <pippin gimp org>
Date: Wed May 25 02:24:55 2011 +0100
add parsing of speaker notes
pinpoint.c | 28 +++++++++++++++++++++++-----
pinpoint.h | 6 ++++--
2 files changed, 27 insertions(+), 7 deletions(-)
---
diff --git a/pinpoint.c b/pinpoint.c
index ec58c96..a575ca7 100644
--- a/pinpoint.c
+++ b/pinpoint.c
@@ -64,6 +64,8 @@ static PinPointPoint default_point = {
.text_align = PP_TEXT_LEFT,
.use_markup = TRUE,
+ .speaker_notes = NULL,
+
.shading_color = "black",
.shading_opacity = 0.66,
.transition = NULL,
@@ -415,6 +417,10 @@ pin_point_free (PinPointRenderer *renderer,
{
if (renderer->free_data)
renderer->free_data (renderer, point->data);
+ if (point->speaker_notes)
+ {
+ g_free (point->speaker_notes);
+ }
g_free (point);
}
@@ -458,12 +464,13 @@ pp_parse_slides (PinPointRenderer *renderer,
const char *slide_src)
{
const char *p;
- int slideno = 0;
- gboolean done = FALSE;
+ int slideno = 0;
+ gboolean done = FALSE;
gboolean startofline = TRUE;
- gboolean gotconfig = FALSE;
- GString *slide_str = g_string_new ("");
+ gboolean gotconfig = FALSE;
+ GString *slide_str = g_string_new ("");
GString *setting_str = g_string_new ("");
+ GString *notes_str = g_string_new ("");
GList *s;
PinPointPoint *point, *next_point;
@@ -546,6 +553,7 @@ pp_parse_slides (PinPointRenderer *renderer,
gotconfig = TRUE;
g_string_assign (slide_str, "");
g_string_assign (setting_str, "");
+ g_string_assign (notes_str, "");
}
else
{
@@ -582,11 +590,14 @@ pp_parse_slides (PinPointRenderer *renderer,
point->text = g_intern_string (str);
}
+ if (notes_str->str[0])
+ point->speaker_notes = g_strdup (notes_str->str);
renderer->make_point (renderer, point);
g_string_assign (slide_str, "");
g_string_assign (setting_str, "");
+ g_string_assign (notes_str, "");
pp_slides = g_list_append (pp_slides, point);
point = next_point;
@@ -600,9 +611,15 @@ pp_parse_slides (PinPointRenderer *renderer,
case '#': /* comment */
if (startofline)
{
- char *end = strchr (p, '\n');
+ const char *end = p + 1;
+ while (*end != '\n' && *end != '\0')
+ {
+ g_string_append_c (notes_str, *end);
+ end++;
+ }
if (end)
{
+ g_string_append_c (notes_str, '\n');
p = end;
break;
}
@@ -623,6 +640,7 @@ pp_parse_slides (PinPointRenderer *renderer,
g_string_free (slide_str, TRUE);
g_string_free (setting_str, TRUE);
+ g_string_free (notes_str, TRUE);
if (g_list_nth (pp_slides, slideno))
pp_slidep = g_list_nth (pp_slides, slideno);
diff --git a/pinpoint.h b/pinpoint.h
index cb02d39..fc5e074 100644
--- a/pinpoint.h
+++ b/pinpoint.h
@@ -35,9 +35,9 @@ typedef struct _PinPointRenderer PinPointRenderer;
typedef enum
{
- PP_TEXT_LEFT = PANGO_ALIGN_LEFT,
+ PP_TEXT_LEFT = PANGO_ALIGN_LEFT,
PP_TEXT_CENTER = PANGO_ALIGN_CENTER,
- PP_TEXT_RIGHT = PANGO_ALIGN_RIGHT
+ PP_TEXT_RIGHT = PANGO_ALIGN_RIGHT
} PPTextAlign;
typedef enum
@@ -88,6 +88,8 @@ struct _PinPointPoint
const char *text_color;
gboolean use_markup;
+ char *speaker_notes; /* speaker comments for the slide */
+
const char *shading_color;
float shading_opacity;
const char *transition; /* transition template to use, if any */
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]