aboutsummaryrefslogtreecommitdiff
path: root/common
diff options
context:
space:
mode:
authorFurkan Sahin <furkan-dev@proton.me>2018-10-16 21:39:37 -0400
committerFurkan Sahin <furkan-dev@proton.me>2018-10-16 21:39:37 -0400
commit5e1a53659eb03d3f433e767d9ffa3a7c6b834301 (patch)
tree8a17c1f3dfa4c4f009063b6c53e93223837fad10 /common
parent95e8933e54df8bcfdd5139ca9eed9623280efa8c (diff)
parent27a20362a97e6e5939add3764a3c95a92465be7f (diff)
Merge pull request #2843 from c-edw/feature/2842_TruncateMessage
swaynag: Truncate message to 2048 chars.
Diffstat (limited to 'common')
-rw-r--r--common/pango.c15
1 files changed, 9 insertions, 6 deletions
diff --git a/common/pango.c b/common/pango.c
index ba74692e..f0b8db66 100644
--- a/common/pango.c
+++ b/common/pango.c
@@ -10,6 +10,9 @@
#include "log.h"
#include "stringop.h"
+static const char *overflow = "[buffer overflow]";
+static const int max_chars = 16384;
+
size_t escape_markup_text(const char *src, char *dest) {
size_t length = 0;
if (dest) {
@@ -84,12 +87,12 @@ PangoLayout *get_pango_layout(cairo_t *cairo, const char *font,
void get_text_size(cairo_t *cairo, const char *font, int *width, int *height,
int *baseline, double scale, bool markup, const char *fmt, ...) {
- static char buf[2048];
+ char buf[max_chars];
va_list args;
va_start(args, fmt);
- if (vsnprintf(buf, 2048, fmt, args) >= 2048) {
- strcpy(buf, "[buffer overflow]");
+ if (vsnprintf(buf, sizeof(buf), fmt, args) >= max_chars) {
+ strcpy(&buf[sizeof(buf) - sizeof(overflow)], overflow);
}
va_end(args);
@@ -104,12 +107,12 @@ void get_text_size(cairo_t *cairo, const char *font, int *width, int *height,
void pango_printf(cairo_t *cairo, const char *font,
double scale, bool markup, const char *fmt, ...) {
- static char buf[2048];
+ char buf[max_chars];
va_list args;
va_start(args, fmt);
- if (vsnprintf(buf, 2048, fmt, args) >= 2048) {
- strcpy(buf, "[buffer overflow]");
+ if (vsnprintf(buf, sizeof(buf), fmt, args) >= max_chars) {
+ strcpy(&buf[sizeof(buf) - sizeof(overflow)], overflow);
}
va_end(args);