shithub: mc

Download patch

ref: d3672bb4f2ef344e41ff7fd3cb8c801a8edc6513
parent: b8739b70c8fbb2f8930c7cb2b1d1a6544aa7024f
author: Ori Bernstein <[email protected]>
date: Sun Apr 12 20:58:08 EDT 2015

Implement getcwd() on Linux.

    This is needed for the newest mbld.

--- a/libstd/Makefile
+++ b/libstd/Makefile
@@ -48,6 +48,7 @@
 	fltbits.myr \
 	fmt.myr \
 	fltfmt.myr \
+	getcwd.myr \
 	hashfuncs.myr \
 	hasprefix.myr \
 	hassuffix.myr \
--- a/libstd/bldfile
+++ b/libstd/bldfile
@@ -36,21 +36,22 @@
 	endian.myr
 	env+posixy.myr
 	env+plan9.myr
-        errno.myr
+	errno.myr
 	execvp.myr
 	extremum.myr
 	fltbits.myr
 	fltfmt.myr
 	fmt.myr
+	getcwd.myr
 	hashfuncs.myr
 	hasprefix.myr
 	hassuffix.myr
 	htab.myr
-        getint.myr
+	getint.myr
 	intparse.myr
 	ipparse.myr
 	mk.myr
-        mkpath.myr
+	mkpath.myr
 	now.myr
 	option.myr
 	optparse.myr
@@ -75,9 +76,9 @@
 	strjoin.myr
 	strsplit.myr
 	strstrip.myr
-        syswrap+plan9.myr
-        syswrap-ss+posixy-linux.myr
-        syswrap-ss+posixy-osx.myr
+	syswrap+plan9.myr
+	syswrap-ss+posixy-linux.myr
+	syswrap-ss+posixy-osx.myr
 	syswrap+posixy.myr
 	swap.myr
 	try.myr
--- /dev/null
+++ b/libstd/getcwd.myr
@@ -1,0 +1,30 @@
+use "syswrap.use"
+use "errno.use"
+use "alloc.use"
+use "extremum.use"
+use "fmt.use"
+
+pkg std =
+	const getcwd : (-> byte[:])
+;;
+
+const getcwd = {
+	var len, n, buf
+
+	len = 128
+	while true
+		buf = std.slalloc(len)
+		n = bgetcwd(buf)
+		std.put("got %i, buf = %s\n", n, buf[:n])
+		if n >= 0
+			/* n is the length of the nul terminated c string */
+			-> buf[:n-1]
+		elif n != Erange
+			std.slfree(buf)
+			-> ""
+		else
+			len *= 2
+		;;
+	;;
+}
+	
--- a/libstd/sys+linux-x64.myr
+++ b/libstd/sys+linux-x64.myr
@@ -608,6 +608,7 @@
 	generic ioctl	: (fd:fd, req : int64, arg:@a# -> int64)
 	const getdents64	: (fd:fd, buf : byte[:] -> int64)
 	const chdir	: (p : byte[:] -> int64)
+	const getcwd	: (buf : byte[:] -> int64)
 
 	/* fd stuff */
 	const pipe	: (fds : fd[2]# -> int64)
@@ -726,6 +727,7 @@
 generic ioctl	= {fd, req, arg;	-> syscall(Sysioctl, a(fd), a(req), a(arg)) castto(int64)}
 const getdents64	= {fd, buf;	-> syscall(Sysgetdents64, a(fd), buf castto(byte#), a(buf.len))}
 const chdir	= {dir;	-> syscall(Syschdir, cstring(dir))}
+const getcwd	= {buf;	-> syscall(Sysgetcwd, a(buf), a(buf.len))}
 
 /* file stuff */
 const pipe	= {fds;	-> syscall(Syspipe, a(fds))}
--- a/libstd/syswrap+posixy.myr
+++ b/libstd/syswrap+posixy.myr
@@ -2,6 +2,7 @@
 use "cstrconv.use"
 use "option.use"
 use "types.use"
+use "errno.use"
 
 pkg std =
 	type fd		= sys.fd
@@ -52,8 +53,8 @@
 
 	/* path manipulation */
 	const mkdir	: (path : byte[:], mode : int64 -> int64)
-	const chdir	: (path : byte[:] -> bool)
 	const remove	: (path : byte[:] -> bool)
+	const chdir	: (path : byte[:] -> bool)
 
 	/* process stuff */
 	const getpid	: ( -> pid)
@@ -67,6 +68,7 @@
 	pkglocal const getmem	: (sz : size -> byte#)
 	pkglocal const freemem	: (p : byte#, sz : size -> void)
 	pkglocal const curtime	: (-> time)
+	pkglocal const bgetcwd	: (buf : byte[:] -> errno)
 ;;
 
 /* fd stuff */
@@ -84,6 +86,7 @@
 const mkdir	= {path, mode;	-> sys.mkdir(path, mode)}
 const chdir	= {path;	-> sys.chdir(path) == 0}
 const remove	= {path;	-> sys.unlink(path) == 0}
+const bgetcwd	= {buf;		-> sys.getcwd(buf) castto(errno)}
 
 /* useful/portable bits of uname */
 const getsysinfo = {si