aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBrian Ashworth <RedSoxFan@users.noreply.github.com>2018-10-16 21:39:37 -0400
committerGitHub <noreply@github.com>2018-10-16 21:39:37 -0400
commit434cbaabf092ec1688b4dfd2d93f38e849531d96 (patch)
tree8a17c1f3dfa4c4f009063b6c53e93223837fad10
parentfa2d2c85590f8a4160d141e43c659cd751ff7471 (diff)
parent3a5a8aa5adec0ff86f75895bde141d93dbb58d34 (diff)
Merge pull request #2843 from c-edw/feature/2842_TruncateMessage
swaynag: Truncate message to 2048 chars.
-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);