From: Eon S. Jeon Date: Mon, 5 Aug 2013 20:37:59 +0000 (-0400) Subject: Fix signess of tdefcolor X-Git-Url: https://jasonwoof.com/gitweb/?p=st.git;a=commitdiff_plain;h=347a45c35299c94e97c976b6e1df383dc2b8fbda Fix signess of tdefcolor tdefcolor() returns -1 on error, while its return type is unsigned long. At the same time, line 1724 and 1731 are checking the positivity of its unsigned return value. --- diff --git a/st.c b/st.c index 9cdd969..1b01353 100644 --- a/st.c +++ b/st.c @@ -362,7 +362,7 @@ static void tsetdirtattr(int); static void tsetmode(bool, bool, int *, int); static void tfulldirt(void); static void techo(char *, int); -static ulong tdefcolor(int *, int *, int); +static long tdefcolor(int *, int *, int); static inline bool match(uint, uint); static void ttynew(void); static void ttyread(void); @@ -1626,7 +1626,7 @@ tdeleteline(int n) { tscrollup(term.c.y, n); } -ulong +long tdefcolor(int *attr, int *npar, int l) { long idx = -1; uint r, g, b; @@ -1677,7 +1677,7 @@ tdefcolor(int *attr, int *npar, int l) { void tsetattr(int *attr, int l) { int i; - ulong idx; + long idx; for(i = 0; i < l; i++) { switch(attr[i]) {