shithub: riscv

Download patch

ref: c6aa11d04e721aebe5cb2969166785fa37652cd7
parent: 2a5b2f4c76fe85aa37d5d99adc13f6d1f1e313e3
author: BurnZeZ <[email protected]>
date: Tue Mar 1 16:24:35 EST 2016

dict: similar fixes, different files. also remove runescpy

--- a/sys/src/cmd/dict/dict.c
+++ b/sys/src/cmd/dict/dict.c
@@ -74,22 +74,18 @@
 	}
 	ARGBEGIN {
 		case 'd':
-			p = ARGF();
+			p = EARGF(usage());
 			dict = 0;
-			if(p) {
-				for(i=0; dicts[i].name; i++)
-					if(strcmp(p, dicts[i].name)==0) {
-						dict = &dicts[i];
-						break;
-					}
-			}
+			for(i=0; dicts[i].name; i++)
+				if(strcmp(p, dicts[i].name)==0) {
+					dict = &dicts[i];
+					break;
+				}
 			if(!dict)
 				usage();
 			break;
 		case 'c':
-			line = ARGF();
-			if(!line)
-				usage();
+			line = EARGF(usage());
 			break;
 		case 'k':
 			kflag++;
@@ -99,7 +95,7 @@
 			break;
 		default:
 			usage();
-	ARGEND }
+	}ARGEND
 	if(dict == 0){
 		err("no dictionaries present on this system");
 		exits("nodict");
@@ -354,7 +350,7 @@
 
 	prelen = getpref(pat+1, pre);
 	if(pat[prelen+1] == 0 || pat[prelen+1] == '$') {
-		runescpy(lit, pre);
+		runestrcpy(lit, pre);
 		if(dofold)
 			fold(lit);
 		needre = 0;
@@ -390,10 +386,8 @@
 				n = 2*dot->maxn;
 				dot = realloc(dot,
 					sizeof(Addr)+(n-1)*sizeof(long));
-				if(!dot) {
-					err("out of memory");
-					exits("nomem");
-				}
+				if(dot == nil)
+					sysfatal("realloc: %r");
 				dot->maxn = n;
 			}
 			dot->doff[dot->n++] = v;
@@ -609,10 +603,8 @@
 		n = e-b;
 		if(n+1 > anslen) {
 			ans.start = realloc(ans.start, n+1);
-			if(!ans.start) {
-				err("out of memory");
-				exits("nomem");
-			}
+			if(ans.start == nil)
+				sysfatal("realloc: %r");
 			anslen = n+1;
 		}
 		Bseek(bdict, b, 0);
--- a/sys/src/cmd/dict/dict.h
+++ b/sys/src/cmd/dict/dict.h
@@ -109,7 +109,6 @@
 void	outchars(char *);
 void	outnl(int);
 void	outpiece(char *, char *);
-void	runescpy(Rune*, Rune*);
 long	runetol(Rune*);
 
 long	oednextoff(long);
--- a/sys/src/cmd/dict/robert.c
+++ b/sys/src/cmd/dict/robert.c
@@ -105,7 +105,8 @@
 
 	if(db == 0)
 		db = Bouvrir(dfile);
-	def.start = malloc(dl+1);
+	if((def.start = malloc(dl+1)) == nil)
+		sysfatal("malloc: %r");
 	def.end = def.start + dl;
 	def.doff = da;
 	Bseek(db, da, 0);
@@ -116,7 +117,8 @@
 	}else{
 		if(eb == 0)
 			eb = Bouvrir(efile);
-		etym.start = malloc(el+1);
+		if((etym.start = malloc(el+1)) == nil)
+			sysfatal("malloc: %r");
 		etym.end = etym.start + el;
 		etym.doff = ea;
 		Bseek(eb, ea, 0);
--- a/sys/src/cmd/dict/utils.c
+++ b/sys/src/cmd/dict/utils.c
@@ -498,16 +498,6 @@
 }
 
 /*
- * Copy null terminated Runes from 'from' to 'to'.
- */
-void
-runescpy(Rune *to, Rune *from)
-{
-	while((*to++ = *from++) != 0)
-		continue;
-}
-
-/*
  * Conversion of unsigned number to long, no overflow detection
  */
 long