Skip site navigation (1)Skip section navigation (2)
Date:      Sat, 20 Sep 2014 12:59:28 +0000 (UTC)
From:      Jilles Tjoelker <jilles@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-stable@freebsd.org, svn-src-stable-9@freebsd.org
Subject:   svn commit: r271902 - stable/9/usr.bin/pathchk
Message-ID:  <201409201259.s8KCxSs1085720@svn.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: jilles
Date: Sat Sep 20 12:59:28 2014
New Revision: 271902
URL: http://svnweb.freebsd.org/changeset/base/271902

Log:
  MFC r256800: pathchk: Ensure bytes >= 128 are considered non-portable
  characters.
  
  This was not broken on architectures such as ARM where char is unsigned.
  
  Also, remove the first non-portable character from the output. POSIX does
  not require this, and printing the first byte may yield an invalid byte
  sequence with UTF-8.
  
  PR:		165988
  Reported by:	Nicolas Rachinsky
  Relnotes:	yes

Modified:
  stable/9/usr.bin/pathchk/pathchk.c
Directory Properties:
  stable/9/usr.bin/pathchk/   (props changed)

Modified: stable/9/usr.bin/pathchk/pathchk.c
==============================================================================
--- stable/9/usr.bin/pathchk/pathchk.c	Sat Sep 20 09:18:58 2014	(r271901)
+++ stable/9/usr.bin/pathchk/pathchk.c	Sat Sep 20 12:59:28 2014	(r271902)
@@ -98,7 +98,7 @@ check(const char *path)
 {
 	struct stat sb;
 	long complen, namemax, pathmax, svnamemax;
-	int badch, last;
+	int last;
 	char *end, *p, *pathd;
 
 	if ((pathd = strdup(path)) == NULL)
@@ -142,9 +142,9 @@ check(const char *path)
 			goto bad;
 		}
 
-		if (pflag && (badch = portable(p)) >= 0) {
+		if (pflag && !portable(p)) {
 			warnx("%s: %s: component contains non-portable "
-			    "character `%c'", path, p, badch);
+			    "character", path, p);
 			goto bad;
 		}
 
@@ -183,8 +183,7 @@ bad:	free(pathd);
 }
 
 /*
- * Check whether a path component contains only portable characters. Return
- * the first non-portable character found.
+ * Check whether a path component contains only portable characters.
  */
 static int
 portable(const char *path)
@@ -197,7 +196,7 @@ portable(const char *path)
 
 	s = strspn(path, charset);
 	if (path[s] != '\0')
-		return (path[s]);
+		return (0);
 
-	return (-1);
+	return (1);
 }



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201409201259.s8KCxSs1085720>