diff options
author | NRK <nrk@disroot.org> | 2022-03-28 01:02:52 +0600 |
---|---|---|
committer | Hiltjo Posthuma <hiltjo@codemadness.org> | 2022-04-16 16:21:01 +0200 |
commit | e4827b0c4048718ab06670cf60ef68d028fe7fc4 (patch) | |
tree | a891006adb7acf63b8c9e4f17ce71ae1baa403ed /drw.c | |
parent | e73651f12a406629778f02d8e5acbe2caec0dfc2 (diff) | |
download | dmenu-e4827b0c4048718ab06670cf60ef68d028fe7fc4.tar.gz dmenu-e4827b0c4048718ab06670cf60ef68d028fe7fc4.zip |
drw_text: don't segfault when called with 0 width
this patch just rejects *any* 0 width draws, which is surely an error by
the caller.
this also guards against cases where the width is too small for the
ellipsis to fit, so ellipsis_w will remain 0.
reported by Bakkeby <bakkeby@gmail.com>
Diffstat (limited to 'drw.c')
-rw-r--r-- | drw.c | 2 |
1 files changed, 1 insertions, 1 deletions
@@ -267,7 +267,7 @@ drw_text(Drw *drw, int x, int y, unsigned int w, unsigned int h, unsigned int lp enum { nomatches_len = 64 }; static struct { long codepoint[nomatches_len]; unsigned int idx; } nomatches; - if (!drw || (render && !drw->scheme) || !text || !drw->fonts) + if (!drw || (render && (!drw->scheme || !w)) || !text || !drw->fonts) return 0; if (!render) { |