herbe

[fork] notifications
Log | Files | Refs | README | LICENSE

commit ed9d201bceea59483e68a9ce3c4c02ba7db2aa97
parent 6a655a7cbd0a0d8e0e6a89e6c82b7787ab27dd59
Author: Samuel Dudik <samuel.dudik@gmail.com>
Date:   Sat,  1 Aug 2020 12:54:00 +0200

Progress with multiline/word-wrap support

Diffstat:
Mconfig.h | 6+++---
Mherbe.c | 31++++++++++++++++++++++++++++---
Mmakefile | 2+-
3 files changed, 32 insertions(+), 7 deletions(-)

diff --git a/config.h b/config.h @@ -1,10 +1,10 @@ const static char *background_color = "#3e3e3e"; const static char *border_color = "#ececec"; const static char *font_color = "#ececec"; -const static char *font_pattern = "Inconsolata:style=Medium:size=15"; +const static char *font_pattern = "Inconsolata:style=Medium:size=13"; const static unsigned int padding = 15; -const static unsigned int width = 300; +const static unsigned int width = 200; const static unsigned int border_size = 2; const static unsigned int pos_x = 40; const static unsigned int pos_y = 50; @@ -12,4 +12,4 @@ const static unsigned int pos_y = 50; enum corners { TOP_LEFT, TOP_RIGHT, BOTTOM_LEFT, BOTTOM_RIGHT }; enum corners corner = TOP_RIGHT; -const static unsigned int duration = 5; /* in seconds */ +const static unsigned int duration = 15; /* in seconds */ diff --git a/herbe.c b/herbe.c @@ -4,6 +4,7 @@ #include <stdlib.h> #include <signal.h> #include <unistd.h> +#include <math.h> #include "config.h" @@ -31,6 +32,16 @@ int get_eol(char *body, XftFont *font) } return --eol; + + // if (body[eol] == ' ') + // return --eol; + + // while (body[eol] != ' ') + // { + // eol--; + // } + + // return ++eol; } void expire() @@ -95,9 +106,13 @@ int main(int argc, char *argv[]) y = window_height - height - border_size * 2 - pos_y; } + XGlyphInfo info; + XftTextExtentsUtf8(display, font, body, strlen(body), &info); + int num_of_lines = ceil((float)info.width / (width - 2 * padding)); + window = XCreateWindow( display, RootWindow(display, screen), x, - y, width, height, border_size, + y, width, (num_of_lines - 1) * 5 + num_of_lines * (font->ascent - font->descent) + 2 * padding, border_size, DefaultDepth(display, screen), CopyFromParent, visual, CWOverrideRedirect | CWBackPixel | CWBorderPixel, &attributes); @@ -109,7 +124,13 @@ int main(int argc, char *argv[]) XMapWindow(display, window); - int eol = get_eol(body, font); + int eols[num_of_lines + 1]; + eols[0] = 0; + + for (int i = 1; i < num_of_lines + 1; i++) + { + eols[i] = eols[i - 1] + get_eol(body + eols[i - 1], font); + } XEvent event; @@ -120,7 +141,11 @@ int main(int argc, char *argv[]) if (event.type == Expose) { XClearWindow(display, window); - XftDrawStringUtf8(draw, &color, font, padding, height - padding, body, eol); + + for (int i = 1; i < num_of_lines + 1; i++) + { + XftDrawStringUtf8(draw, &color, font, padding, 5 * (i - 1) + (font->ascent - font->descent) * i + padding, body + eols[i - 1], eols[i] - eols[i - 1]); + } } if (event.type == ButtonPress) break; diff --git a/makefile b/makefile @@ -1,5 +1,5 @@ default: - gcc herbe.c -lX11 -lXft -I/usr/include/freetype2 -o herbe + gcc herbe.c -lX11 -lXft -I/usr/include/freetype2 -lm -o herbe install: default cp herbe /usr/local/bin