ref: cefb84c2dbec914dc2733f776bb39d9055034c92
parent: 2d333750272c3967cfd5cd3677572cddeaad5932
author: Franklin Wei <me@fwei.tk>
date: Fri Apr 28 15:48:36 EDT 2017
Work around non-compliant sprintf(). Rockbox's sprintf() lacks the ability to left-justify a string. Fixed by adding a copy_left_justfied() function to misc.c. This is a new version of this commit, as the previous version broke saving!
--- a/midend.c
+++ b/midend.c
@@ -1610,7 +1610,9 @@
#define wr(h,s) do { \
char hbuf[80]; \
char *str = (s); \
- sprintf(hbuf, "%-8.8s:%d:", (h), (int)strlen(str)); \
+ char lbuf[9]; \
+ copy_left_justified(lbuf, sizeof(lbuf), h); \
+ sprintf(hbuf, "%s:%d:", lbuf, (int)strlen(str)); \
write(wctx, hbuf, strlen(hbuf)); \
write(wctx, str, strlen(str)); \
write(wctx, "\n", 1); \
--- a/misc.c
+++ b/misc.c
@@ -358,6 +358,19 @@
draw_text(dr, x, y+1, fonttype, fontsize, align, outline_colour, text);
}
draw_text(dr, x, y, fonttype, fontsize, align, text_colour, text);
+
+}
+
+/* kludge for non-compliant sprintf() */
+void copy_left_justified(char *buf, size_t sz, const char *str)
+{
+ memset(buf, ' ', sz - 1);
+ int len = strlen(str);
+ if(len <= sz - 1)
+ memcpy(buf, str, len);
+ else
+ fatal("overrun");
+ buf[sz - 1] = 0;
}
/* vim: set shiftwidth=4 tabstop=8: */
--- a/puzzles.h
+++ b/puzzles.h
@@ -376,6 +376,11 @@
void draw_text_outline(drawing *dr, int x, int y, int fonttype,
int fontsize, int align,
int text_colour, int outline_colour, char *text);
+
+/* Copies text left-justified with spaces. Length of string must be
+ * less than buffer size. */
+void copy_left_justified(char *buf, size_t sz, const char *str);
+
/*
* dsf.c
*/