aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDrew DeVault <sir@cmpwn.com>2016-10-07 08:39:50 -0400
committerDrew DeVault <sir@cmpwn.com>2016-10-12 21:42:34 -0400
commit61097085b0b3207a89d75665d6d18229259d89f1 (patch)
tree3149dd2c8ad51de63759c4992c572a665b6911a4
parent28c0426e855f7cbbd2a5bd6941cd4b13f97700e2 (diff)
downloadsway-61097085b0b3207a89d75665d6d18229259d89f1.zip
sway-61097085b0b3207a89d75665d6d18229259d89f1.tar.gz
sway-61097085b0b3207a89d75665d6d18229259d89f1.tar.bz2
Merge pull request #936 from thejan2009/pango-numeric-char-ref
parse pango markup in workspace names (and bugfix)
-rw-r--r--swaybar/render.c4
-rw-r--r--wayland/pango.c6
2 files changed, 6 insertions, 4 deletions
diff --git a/swaybar/render.c b/swaybar/render.c
index a773df7..7dfac89 100644
--- a/swaybar/render.c
+++ b/swaybar/render.c
@@ -205,7 +205,7 @@ void workspace_button_size(struct window *window, const char *workspace_name, in
const char *stripped_name = strip_workspace_name(swaybar.config->strip_workspace_numbers, workspace_name);
get_text_size(window->cairo, window->font, width, height,
- window->scale, false, "%s", stripped_name);
+ window->scale, true, "%s", stripped_name);
*width += 2 * ws_horizontal_padding;
*height += 2 * ws_vertical_padding;
}
@@ -241,7 +241,7 @@ static void render_workspace_button(struct window *window, struct config *config
cairo_set_source_u32(window->cairo, box_colors.text);
cairo_move_to(window->cairo, (int)*x + ws_horizontal_padding, margin);
pango_printf(window->cairo, window->font, window->scale,
- false, "%s", stripped_name);
+ true, "%s", stripped_name);
*x += width + ws_spacing;
}
diff --git a/wayland/pango.c b/wayland/pango.c
index 3899324..5781541 100644
--- a/wayland/pango.c
+++ b/wayland/pango.c
@@ -11,9 +11,10 @@ PangoLayout *get_pango_layout(cairo_t *cairo, const char *font, const char *text
int32_t scale, bool markup) {
PangoLayout *layout = pango_cairo_create_layout(cairo);
PangoAttrList *attrs = pango_attr_list_new();
+ char *buf = malloc(2048);
if (markup) {
- pango_parse_markup(text, -1, 0, &attrs, NULL, NULL, NULL);
- pango_layout_set_markup(layout, text, -1);
+ pango_parse_markup(text, -1, 0, &attrs, &buf, NULL, NULL);
+ pango_layout_set_markup(layout, buf, -1);
} else {
pango_layout_set_text(layout, text, -1);
}
@@ -24,6 +25,7 @@ PangoLayout *get_pango_layout(cairo_t *cairo, const char *font, const char *text
pango_layout_set_attributes(layout, attrs);
pango_attr_list_unref(attrs);
pango_font_description_free(desc);
+ free(buf);
return layout;
}