jcf.h (COMPARE_FILENAMES): New macro similar to "strcmp" to compare file name components depending on the...

2003-03-05  Ranjit Mathew  <rmathew@hotmail.com>

	* jcf.h (COMPARE_FILENAMES): New macro similar to "strcmp" to
	compare file name components depending on the case-sensitivity
	or otherwise of the host file system.

	* jcf-path.c (add_entry): Use COMPARE_FILENAMES instead of
	"strcmp" to compare file name components.
	Use IS_DIR_SEPARATOR instead of comparing directly against
	DIR_SEPARATOR.
	(jcf_path_extdirs_arg): Use IS_DIR_SEPARATOR instead of
	comparing directly against DIR_SEPARATOR.

From-SVN: r63927
This commit is contained in:
Ranjit Mathew 2003-03-07 04:40:08 +00:00 committed by Tom Tromey
parent 203b3521b5
commit 530d4230db
3 changed files with 28 additions and 5 deletions

View File

@ -1,3 +1,16 @@
2003-03-05 Ranjit Mathew <rmathew@hotmail.com>
* jcf.h (COMPARE_FILENAMES): New macro similar to "strcmp" to
compare file name components depending on the case-sensitivity
or otherwise of the host file system.
* jcf-path.c (add_entry): Use COMPARE_FILENAMES instead of
"strcmp" to compare file name components.
Use IS_DIR_SEPARATOR instead of comparing directly against
DIR_SEPARATOR.
(jcf_path_extdirs_arg): Use IS_DIR_SEPARATOR instead of
comparing directly against DIR_SEPARATOR.
2003-03-04 Tom Tromey <tromey@redhat.com> 2003-03-04 Tom Tromey <tromey@redhat.com>
* Make-lang.in (java.tags): New target. * Make-lang.in (java.tags): New target.

View File

@ -146,22 +146,23 @@ add_entry (struct entry **entp, const char *filename, int is_system)
n->next = NULL; n->next = NULL;
len = strlen (filename); len = strlen (filename);
if (len > 4 && (strcmp (filename + len - 4, ".zip") == 0
|| strcmp (filename + len - 4, ".jar") == 0)) if (len > 4 && (COMPARE_FILENAMES (filename + len - 4, ".zip") == 0
|| COMPARE_FILENAMES (filename + len - 4, ".jar") == 0))
{ {
n->flags |= FLAG_ZIP; n->flags |= FLAG_ZIP;
/* If the user uses -classpath then he'll have to include /* If the user uses -classpath then he'll have to include
libgcj.jar in the value. We check for this in a simplistic libgcj.jar in the value. We check for this in a simplistic
way. Symlinks will fool this test. This is only used for way. Symlinks will fool this test. This is only used for
-MM and -MMD, so it probably isn't terribly important. */ -MM and -MMD, so it probably isn't terribly important. */
if (! strcmp (filename, LIBGCJ_ZIP_FILE)) if (! COMPARE_FILENAMES (filename, LIBGCJ_ZIP_FILE))
n->flags |= FLAG_SYSTEM; n->flags |= FLAG_SYSTEM;
} }
/* Note that we add a trailing separator to `.zip' names as well. /* Note that we add a trailing separator to `.zip' names as well.
This is a little hack that lets the searching code in jcf-io.c This is a little hack that lets the searching code in jcf-io.c
work more easily. Eww. */ work more easily. Eww. */
if (filename[len - 1] != '/' && filename[len - 1] != DIR_SEPARATOR) if (! IS_DIR_SEPARATOR (filename[len - 1]))
{ {
char *f2 = alloca (len + 2); char *f2 = alloca (len + 2);
strcpy (f2, filename); strcpy (f2, filename);
@ -370,7 +371,7 @@ jcf_path_extdirs_arg (const char *cp)
char *name = alloca (dirname_length char *name = alloca (dirname_length
+ strlen (direntp->d_name) + 2); + strlen (direntp->d_name) + 2);
strcpy (name, buf); strcpy (name, buf);
if (name[dirname_length-1] != DIR_SEPARATOR) if (! IS_DIR_SEPARATOR (name[dirname_length-1]))
{ {
name[dirname_length] = DIR_SEPARATOR; name[dirname_length] = DIR_SEPARATOR;
name[dirname_length+1] = 0; name[dirname_length+1] = 0;

View File

@ -54,6 +54,15 @@ The Free Software Foundation is independent of Sun Microsystems, Inc. */
#define JCF_USE_SCANDIR 0 #define JCF_USE_SCANDIR 0
#endif #endif
/* On case-insensitive file systems, file name components must be
compared using "strcasecmp", if available, instead of "strcmp".
Assumes "config.h" has already been included. */
#if defined (HAVE_DOS_BASED_FILE_SYSTEM) && defined (HAVE_STRCASECMP)
#define COMPARE_FILENAMES(X, Y) strcasecmp ((X), (Y))
#else
#define COMPARE_FILENAMES(X, Y) strcmp ((X), (Y))
#endif
struct JCF; struct JCF;
typedef int (*jcf_filbuf_t) PARAMS ((struct JCF*, int needed)); typedef int (*jcf_filbuf_t) PARAMS ((struct JCF*, int needed));