shithub: mc

Download patch

ref: dd5712495a3b7a16dcc48f93c7c9017bf79b6218
parent: 5a7ad6eb2cb497076f909e54e14d42f65eb89ff9
author: andrewc <[email protected]>
date: Thu Feb 11 06:30:44 EST 2016

stop mbld from opening a directory

--- a/lib/std/syswrap+posixy.myr
+++ b/lib/std/syswrap+posixy.myr
@@ -48,6 +48,7 @@
 	const fsize	: (f : byte[:]	-> result(off, errno))
 	const fexists	: (f : byte[:]	-> bool)
 	const fisdir	: (f : byte[:]	-> bool)
+	const fisreg	: (f : byte[:]	-> bool)
 
 	/* useful/portable bits of uname */
 	const getsysinfo	: (si : sysinfo# -> void)
@@ -130,6 +131,16 @@
 
 	if sys.stat(path, &sb) >= 0
 		-> sb.mode & sys.Sifdir != 0
+	else
+		-> false
+	;;
+}
+
+const fisreg = {path
+	var sb
+
+	if sys.stat(path, &sb) >= 0
+		-> sb.mode & sys.Sifreg != 0
 	else
 		-> false
 	;;
--- a/lib/std/syswrap-ss+freebsd.myr
+++ b/lib/std/syswrap-ss+freebsd.myr
@@ -5,7 +5,7 @@
 use "die"
 
 pkg std =
-	const exit	: (status:int -> void)
+	$noret const exit	: (status:int -> void)
 	pkglocal const bgetcwd	: (buf : byte[:] -> errno)
 ;;
 
--- a/lib/std/syswrap-ss+linux.myr
+++ b/lib/std/syswrap-ss+linux.myr
@@ -2,7 +2,7 @@
 use "errno"
 
 pkg std =
-	const exit	: (status:int -> void)
+	$noret const exit	: (status:int -> void)
 	pkglocal const bgetcwd	: (buf : byte[:] -> errno)
 ;;
 
--- a/lib/std/syswrap-ss+osx.myr
+++ b/lib/std/syswrap-ss+osx.myr
@@ -5,7 +5,7 @@
 use "die"
 
 pkg std =
-	const exit	: (status:int -> void)
+	$noret const exit	: (status:int -> void)
 	pkglocal const bgetcwd	: (buf : byte[:] -> errno)
 ;;
 
--- a/mbld/deps.myr
+++ b/mbld/deps.myr
@@ -364,21 +364,35 @@
 
 	for p in incs
 		path = std.pathjoin([p, lib][:])
+		if !std.fisreg(path)
+			std.slfree(path)
+			continue
+		;;
 		match  bio.open(path, bio.Rd)
-		| `std.Ok file:	-> file
-		| `std.Fail m:	/* nothing */
+		| `std.Ok file:
+			std.slfree(path)
+			-> file
+		| `std.Fail m:
+			std.fput(std.Err, "could not open {}: {}\n", path, m)
+			goto error
 		;;
 	;;
 	path = std.pathjoin([opt_instbase, config.Libpath, lib][:])
 	match  bio.open(path, bio.Rd)
-	| `std.Ok file:	-> file
+	| `std.Ok file:
+		std.slfree(path)
+		-> file
 	| `std.Fail m:	/* nothing */
 	;;
-	std.put("could not find library {} in search path:\n", lib)
+	std.fput(std.Err, "could not find library {}\n", lib)
+
+	:error
+	std.fput(std.Err, "search path is:\n")
 	for p in incs
-		std.put("\t{}\n", p)
+		std.fput(std.Err, "\t{}\n", p)
 	;;
-	std.fatal("\t{}\n", config.Libpath)
+	std.fput(std.Err, "\t{}\n", path)
+	std.exit(1)
 }
 
 /* pushes a dep into the dependency list */