diff options
| author | Barry Warsaw <barry@python.org> | 2001-02-02 19:12:16 +0000 | 
|---|---|---|
| committer | Barry Warsaw <barry@python.org> | 2001-02-02 19:12:16 +0000 | 
| commit | 914a0b1db61963e885fa5ee341c958a75b46f65c (patch) | |
| tree | e8dc655f93569fe164f6d30374226f740f67787b /Python/import.c | |
| parent | 5e7cb240afa0d28f19c92ea84a85113cc6eba5bb (diff) | |
| download | cpython-git-914a0b1db61963e885fa5ee341c958a75b46f65c.tar.gz | |
Steve Majewski's patch #103495, MatchFilename() and find_module()
patch for case-preserving HFS+ suport.  Untested except to verify that
it builds and doesn't break anything on Linux RH6.1.
Diffstat (limited to 'Python/import.c')
| -rw-r--r-- | Python/import.c | 53 | 
1 files changed, 53 insertions, 0 deletions
| diff --git a/Python/import.c b/Python/import.c index 533fed5ae0..21c3b2c69a 100644 --- a/Python/import.c +++ b/Python/import.c @@ -836,6 +836,40 @@ static int check_case(char *, int, int, char *);  static int find_init_module(char *); /* Forward */ +#ifdef HAVE_DIRENT_H + +static int MatchFilename(char *pathname, char *filename); + +#include <sys/types.h> +#include <dirent.h> + +static int MatchFilename(char *pathname, char *filename) +{ +	DIR *dirp; +	struct dirent *dp; +	int len = strlen(filename); + +	if ((pathname == NULL) || (strlen(pathname) == 0)) +		pathname = "."; +	dirp = opendir(pathname); +	if (dirp) { +		while ((dp = readdir(dirp)) != NULL) { +#ifdef _DIRENT_HAVE_D_NAMELINE +			int namelen = dp->d_namlen; +#else  /* !_DIRENT_HAVE_D_NAMELINE */ +			int namelen = strlen(dp->d_name); +#endif /* _DIRENT_HAVE_D_NAMELINE */ +			if (namelen == len && !strcmp(dp->d_name, filename)) { +				(void)closedir(dirp); +				return 1; /* Found */ +			} +		} +	} +	(void)closedir(dirp); +	return 0 ; /* Not found */ +} +#endif /* HAVE_DIRENT_H */ +  static struct filedescr *  find_module(char *realname, PyObject *path, char *buf, size_t buflen,  	    FILE **p_fp) @@ -966,8 +1000,27 @@ find_module(char *realname, PyObject *path, char *buf, size_t buflen,  			if (Py_VerboseFlag > 1)  				PySys_WriteStderr("# trying %s\n", buf);  			fp = fopen(buf, fdp->mode); +#ifdef HAVE_DIRENT_H + +		        if (fp != NULL) {  /* check case */ +				char *curpath = PyString_AsString(v); +				char *nstart = buf + strlen(curpath); +				if (*nstart == SEP) +					nstart++;  +				if (MatchFilename(curpath, nstart)) { +					break;      /* Found */ +				} +				fclose(fp); /* No. Close & continue search */ +				fp = NULL; +				if (Py_VerboseFlag > 1) +					PySys_WriteStderr( +					      "# case mismatch for %s:  %s\n",  +					      name, buf); +			} +#else  /* !HAVE_DIRENT_H */  			if (fp != NULL)  				break; +#endif /* HAVE_DIRENT_H */  		}  #endif /* !macintosh */  		if (fp != NULL) | 
