herbe

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

commit 7161997b6ff82cb9f65153d799ffca6720957f25
parent ed9d201bceea59483e68a9ce3c4c02ba7db2aa97
Author: Samuel Dudik <samuel.dudik@gmail.com>
Date:   Sat,  1 Aug 2020 21:00:20 +0200

Finish multiline support

Diffstat:
Mconfig.h | 6++++--
Mherbe.c | 117+++++++++++++++++++++++++++++++++++++-------------------------------------------
Mmakefile | 3++-
3 files changed, 60 insertions(+), 66 deletions(-)

diff --git a/config.h b/config.h @@ -2,14 +2,15 @@ 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=13"; +const static unsigned line_spacing = 5; const static unsigned int padding = 15; 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_x = 30; 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 = 15; /* in seconds */ +const static unsigned int duration = 5; /* in seconds */ +\ No newline at end of file diff --git a/herbe.c b/herbe.c @@ -4,46 +4,12 @@ #include <stdlib.h> #include <signal.h> #include <unistd.h> -#include <math.h> #include "config.h" Display *display; Window window; -int get_eol(char *body, XftFont *font) -{ - int body_len = strlen(body); - XGlyphInfo info; - XftTextExtentsUtf8(display, font, body, body_len, &info); - - int max_text_width = width - 2 * padding; - - if (info.width < max_text_width) - return body_len; - - int eol = max_text_width / font->max_advance_width; - info.width = 0; - - while (info.width < max_text_width) - { - eol++; - XftTextExtentsUtf8(display, font, body, eol, &info); - } - - return --eol; - - // if (body[eol] == ' ') - // return --eol; - - // while (body[eol] != ' ') - // { - // eol--; - // } - - // return ++eol; -} - void expire() { XEvent event; @@ -77,8 +43,8 @@ int main(int argc, char *argv[]) Visual *visual = DefaultVisual(display, screen); Colormap colormap = DefaultColormap(display, screen); - int window_width = DisplayWidth(display, screen); - int window_height = DisplayHeight(display, screen); + int screen_width = DisplayWidth(display, screen); + int screen_height = DisplayHeight(display, screen); XftColor color; @@ -91,31 +57,66 @@ int main(int argc, char *argv[]) XftFont *font = XftFontOpenName(display, screen, font_pattern); + int max_text_width = width - 2 * padding; + int eols_size = 5; + int *eols = malloc(eols_size * sizeof(int)); + eols[0] = 0; + int remainder = strlen(body); + int num_of_lines = 1; + + while (1) + { + XGlyphInfo info; + info.width = 0; + int eol = max_text_width / font->max_advance_width; + while (info.width < max_text_width) + { + eol++; + XftTextExtentsUtf8(display, font, body, eol, &info); + } + + --eol; + + if (eol >= remainder) + { + if (eols_size < num_of_lines + 1) + { + eols_size += 5; + eols = realloc(eols, eols_size * sizeof(int)); + } + eols[num_of_lines] = eols[num_of_lines - 1] + remainder; + num_of_lines++; + break; + } + + remainder -= eol; + if (eols_size < num_of_lines + 1) + { + eols_size += 5; + eols = realloc(eols, eols_size * sizeof(int)); + } + eols[num_of_lines] = eols[num_of_lines - 1] + eol; + num_of_lines++; + } + unsigned int x = pos_x; unsigned int y = pos_y; - unsigned int height = font->ascent - font->descent + padding * 2; + unsigned int text_height = font->ascent - font->descent; + unsigned int height = (num_of_lines - 2) * line_spacing + (num_of_lines - 1) * text_height + 2 * padding; switch (corner) { case BOTTOM_RIGHT: - y = window_height - height - border_size * 2 - pos_y; + y = screen_height - height - border_size * 2 - pos_y; case TOP_RIGHT: - x = window_width - width - border_size * 2 - pos_x; + x = screen_width - width - border_size * 2 - pos_x; break; case BOTTOM_LEFT: - y = window_height - height - border_size * 2 - pos_y; + y = screen_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, (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); + window = XCreateWindow(display, RootWindow(display, screen), x, y, width, height, border_size, DefaultDepth(display, screen), CopyFromParent, visual, + CWOverrideRedirect | CWBackPixel | CWBorderPixel, &attributes); XftDraw *draw = XftDrawCreate(display, window, visual, colormap); XftColorAllocName(display, visual, colormap, font_color, &color); @@ -124,14 +125,6 @@ int main(int argc, char *argv[]) XMapWindow(display, window); - 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; while (1) @@ -141,16 +134,14 @@ int main(int argc, char *argv[]) if (event.type == Expose) { XClearWindow(display, window); - - 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]); - } + for (int i = 1; i < num_of_lines; i++) + XftDrawStringUtf8(draw, &color, font, padding, line_spacing * (i - 1) + text_height * i + padding, body + eols[i - 1], eols[i] - eols[i - 1]); } if (event.type == ButtonPress) break; } + free(eols); XftDrawDestroy(draw); XftColorFree(display, visual, colormap, &color); XftFontClose(display, font); diff --git a/makefile b/makefile @@ -8,4 +8,4 @@ uninstall: rm /usr/local/bin/herbe clean: - rm -f herbe + rm -f herbe +\ No newline at end of file