svn commit: trunk/busybox/libbb

vda at busybox.net vda at busybox.net
Thu Oct 12 06:12:12 UTC 2006


Author: vda
Date: 2006-10-11 23:12:11 -0700 (Wed, 11 Oct 2006)
New Revision: 16369

Log:
execable.c: forgot to do "svn add" again...


Added:
   trunk/busybox/libbb/execable.c


Changeset:
Added: trunk/busybox/libbb/execable.c
===================================================================
--- trunk/busybox/libbb/execable.c	2006-10-12 03:57:13 UTC (rev 16368)
+++ trunk/busybox/libbb/execable.c	2006-10-12 06:12:11 UTC (rev 16369)
@@ -0,0 +1,62 @@
+/* vi: set sw=4 ts=4: */
+/*
+ * Utility routines.
+ *
+ * Copyright (C) 2006 Gabriel Somlo <somlo at cmu.edu>
+ *
+ * Licensed under GPLv2 or later, see file LICENSE in this tarball for details.
+ */
+
+#include "libbb.h"
+
+/* check if path points to an executable file;
+ * return 1 if found;
+ * return 0 otherwise;
+ */
+int execable_file(const char *name)
+{
+	struct stat s;
+	return (!access(name, X_OK) && !stat(name, &s) && S_ISREG(s.st_mode));
+}
+
+/* search $PATH for an executable file;
+ * return allocated string containing full path if found;
+ * return NULL otherwise;
+ */
+char *find_execable(const char *filename)
+{
+	char *path, *p, *n;
+
+	p = path = xstrdup(getenv("PATH") ? : "");
+	while (p) {
+		n = strchr(p, ':');
+		if (n)
+			*n++ = '\0';
+		if (*p != '\0') { /* it's not a PATH="foo::bar" situation */
+			p = concat_path_file(p, filename);
+			if (execable_file(p)) {
+				free(path);
+				return p;
+			}
+			free(p);
+		}
+		p = n;
+	}
+	free(path);
+	return NULL;
+}
+
+/* search $PATH for an executable file;
+ * return 1 if found;
+ * return 0 otherwise;
+ */
+int exists_execable(const char *filename)
+{
+	char *ret = find_execable(filename);
+	if (ret) {
+		free(ret);
+		return 1;
+	}
+	return 0;
+}
+




More information about the busybox-cvs mailing list