shithub: libmujs

Download patch

ref: e4a6860f6ec750782d9e50c8b29883a5cf92eda2
parent: fe723b6f8b0e5381235a9d8da63d251cdf8ae63b
author: Tor Andersson <tor@ccxvii.net>
date: Mon Feb 24 19:22:17 EST 2014

More signedness fixes.

--- a/js.h
+++ b/js.h
@@ -76,8 +76,8 @@
 void js_loadstring(js_State *J, const char *filename, const char *source);
 void js_loadfile(js_State *J, const char *filename);
 
-void js_call(js_State *J, int n);
-void js_construct(js_State *J, int n);
+void js_call(js_State *J, unsigned int n);
+void js_construct(js_State *J, unsigned int n);
 
 const char *js_ref(js_State *J);
 void js_unref(js_State *J, const char *ref);
--- a/jsbuiltin.h
+++ b/jsbuiltin.h
@@ -18,7 +18,7 @@
 void jsB_propn(js_State *J, const char *name, double number);
 void jsB_props(js_State *J, const char *name, const char *string);
 
-typedef struct js_Buffer { int n, m; char s[64]; } js_Buffer;
+typedef struct js_Buffer { unsigned int n, m; char s[64]; } js_Buffer;
 
 static void sb_putc(js_Buffer **sbp, int c)
 {
--- a/jscompile.c
+++ b/jscompile.c
@@ -77,7 +77,7 @@
 
 static int addnumber(JF, double value)
 {
-	int i;
+	unsigned int i;
 	for (i = 0; i < F->numlen; ++i)
 		if (F->numtab[i] == value)
 			return i;
@@ -91,7 +91,7 @@
 
 static int addstring(JF, const char *value)
 {
-	int i;
+	unsigned int i;
 	for (i = 0; i < F->strlen; ++i)
 		if (!strcmp(F->strtab[i], value))
 			return i;
@@ -106,7 +106,7 @@
 static void addlocal(JF, const char *name, int reuse)
 {
 	if (reuse) {
-		int i;
+		unsigned int i;
 		for (i = 0; i < F->varlen; ++i)
 			if (!strcmp(F->vartab[i], name))
 				return;
@@ -120,10 +120,10 @@
 
 static int findlocal(JF, const char *name)
 {
-	int i;
-	for (i = F->varlen - 1; i >= 0; --i)
-		if (!strcmp(F->vartab[i], name))
-			return i + 1;
+	unsigned int i;
+	for (i = F->varlen; i > 0; --i)
+		if (!strcmp(F->vartab[i-1], name))
+			return i;
 	return -1;
 }
 
--- a/jscompile.h
+++ b/jscompile.h
@@ -123,23 +123,23 @@
 	const char *name;
 	int script;
 	int lightweight;
-	int arguments;
-	int numparams;
+	unsigned int arguments;
+	unsigned int numparams;
 
 	short *code;
-	int codecap, codelen;
+	unsigned int codecap, codelen;
 
 	js_Function **funtab;
-	int funcap, funlen;
+	unsigned int funcap, funlen;
 
 	double *numtab;
-	int numcap, numlen;
+	unsigned int numcap, numlen;
 
 	const char **strtab;
-	int strcap, strlen;
+	unsigned int strcap, strlen;
 
 	const char **vartab;
-	int varcap, varlen;
+	unsigned int varcap, varlen;
 
 	const char *filename;
 	int line;
--- a/jsdump.c
+++ b/jsdump.c
@@ -715,7 +715,7 @@
 {
 	short *p = F->code;
 	short *end = F->code + F->codelen;
-	int i;
+	unsigned int i;
 
 	printf("%s(%d)\n", F->name, F->numparams);
 	if (F->lightweight) printf("\tlightweight\n");
--- a/jsfunction.c
+++ b/jsfunction.c
@@ -53,7 +53,7 @@
 {
 	js_Object *self = js_toobject(J, 0);
 	char *s;
-	int i, n;
+	unsigned int i, n;
 
 	if (!js_iscallable(J, 0))
 		js_typeerror(J, "not a function");
--- a/jsgc.c
+++ b/jsgc.c
@@ -53,7 +53,7 @@
 
 static void jsG_markfunction(js_State *J, int mark, js_Function *fun)
 {
-	int i;
+	unsigned int i;
 	fun->gcmark = mark;
 	for (i = 0; i < fun->funlen; ++i)
 		if (fun->funtab[i]->gcmark != mark)
--- a/jsrun.c
+++ b/jsrun.c
@@ -762,11 +762,11 @@
 
 /* Function calls */
 
-static void jsR_calllwfunction(js_State *J, int n, js_Function *F, js_Environment *scope)
+static void jsR_calllwfunction(js_State *J, unsigned int n, js_Function *F, js_Environment *scope)
 {
 	js_Environment *saveE;
 	js_Value v;
-	int i;
+	unsigned int i;
 
 	saveE = J->E;
 
@@ -787,11 +787,11 @@
 	J->E = saveE;
 }
 
-static void jsR_callfunction(js_State *J, int n, js_Function *F, js_Environment *scope)
+static void jsR_callfunction(js_State *J, unsigned int n, js_Function *F, js_Environment *scope)
 {
 	js_Environment *saveE;
 	js_Value v;
-	int i;
+	unsigned int i;
 
 	saveE = J->E;
 
@@ -830,7 +830,7 @@
 	J->E = saveE;
 }
 
-static void jsR_callscript(js_State *J, int n, js_Function *F)
+static void jsR_callscript(js_State *J, unsigned int n, js_Function *F)
 {
 	js_Value v;
 	js_pop(J, n);
@@ -840,7 +840,7 @@
 	js_pushvalue(J, v);
 }
 
-static void jsR_callcfunction(js_State *J, int n, int min, js_CFunction F)
+static void jsR_callcfunction(js_State *J, unsigned int n, int min, js_CFunction F)
 {
 	int rv, i;
 
@@ -858,7 +858,7 @@
 	}
 }
 
-void js_call(js_State *J, int n)
+void js_call(js_State *J, unsigned int n)
 {
 	js_Object *obj;
 	int savebot;
@@ -884,7 +884,7 @@
 	BOT = savebot;
 }
 
-void js_construct(js_State *J, int n)
+void js_construct(js_State *J, unsigned int n)
 {
 	js_Object *obj;
 	js_Object *prototype;
--- a/regex.c
+++ b/regex.c
@@ -552,9 +552,9 @@
 	const char *p;
 };
 
-static int count(Renode *node)
+static unsigned int count(Renode *node)
 {
-	int min, max;
+	unsigned int min, max;
 	if (!node) return 0;
 	switch (node->type) {
 	default: return 1;
@@ -864,7 +864,7 @@
 	return 0;
 }
 
-static int strncmpcanon(const char *a, const char *b, int n)
+static int strncmpcanon(const char *a, const char *b, unsigned int n)
 {
 	Rune ra, rb;
 	int c;
@@ -884,7 +884,8 @@
 {
 	const char *p;
 	Rune c;
-	int n;
+	unsigned int n;
+	int v;
 
 	for (;;) {
 		switch (pc->opcode) {
@@ -918,9 +919,9 @@
 			continue;
 		case I_NLA:
 			++g->nla;
-			n = match(g, pc->x, s);
+			v = match(g, pc->x, s);
 			--g->nla;
-			if (n)
+			if (v)
 				return 0;
 			pc = pc->y;
 			continue;
@@ -965,7 +966,7 @@
 			}
 			break;
 		case I_REF:
-			n = (int)(g->m[pc->n].ep - g->m[pc->n].sp);
+			n = g->m[pc->n].ep - g->m[pc->n].sp;
 			if (g->icase) {
 				if (strncmpcanon(s, g->m[pc->n].sp, n))
 					return 0;
@@ -991,15 +992,15 @@
 					break;
 			return 0;
 		case I_WORD:
-			n = s > g->bol && iswordchar(s[-1]);
-			n ^= iswordchar(s[0]);
-			if (n)
+			v = s > g->bol && iswordchar(s[-1]);
+			v ^= iswordchar(s[0]);
+			if (v)
 				break;
 			return 0;
 		case I_NWORD:
-			n = s > g->bol && iswordchar(s[-1]);
-			n ^= iswordchar(s[0]);
-			if (!n)
+			v = s > g->bol && iswordchar(s[-1]);
+			v ^= iswordchar(s[0]);
+			if (!v)
 				break;
 			return 0;
 		case I_LPAR:
--- a/utf.c
+++ b/utf.c
@@ -42,7 +42,7 @@
 	Bad	= Runeerror,
 };
 
-int
+unsigned int
 chartorune(Rune *rune, const char *str)
 {
 	int c, c1, c2;
@@ -98,10 +98,10 @@
 	return 1;
 }
 
-int
+unsigned int
 runetochar(char *str, const Rune *rune)
 {
-	int c;
+	unsigned int c;
 
 	/*
 	 * one character sequence
@@ -133,7 +133,7 @@
 	return 3;
 }
 
-int
+unsigned int
 runelen(int c)
 {
 	Rune rune;
@@ -143,11 +143,11 @@
 	return runetochar(str, &rune);
 }
 
-int
+unsigned int
 utflen(const char *s)
 {
-	int c;
-	int n;
+	unsigned int c;
+	unsigned int n;
 	Rune rune;
 
 	n = 0;
--- a/utf.h
+++ b/utf.h
@@ -25,10 +25,10 @@
 	Runeerror	= 0xFFFD,	/* decoding error in UTF */
 };
 
-int		chartorune(Rune *rune, const char *str);
-int		runetochar(char *str, const Rune *rune);
-int		runelen(int c);
-int		utflen(const char *s);
+unsigned int	chartorune(Rune *rune, const char *str);
+unsigned int	runetochar(char *str, const Rune *rune);
+unsigned int	runelen(int c);
+unsigned int	utflen(const char *s);
 
 int		isalpharune(Rune c);
 int		islowerrune(Rune c);