summaryrefslogtreecommitdiffstats
path: root/jnlib/stringhelp.c
diff options
context:
space:
mode:
authorWerner Koch <wk@gnupg.org>2007-08-02 20:12:43 +0200
committerWerner Koch <wk@gnupg.org>2007-08-02 20:12:43 +0200
commitebd36b634450ce9fdf0104052cca2b035ad3a22d (patch)
tree1708507fee17d3520460bd94636800d4b828c8ed /jnlib/stringhelp.c
parentApplied exact length hack. (diff)
downloadgnupg2-ebd36b634450ce9fdf0104052cca2b035ad3a22d.tar.xz
gnupg2-ebd36b634450ce9fdf0104052cca2b035ad3a22d.zip
Factored common gpgconf constants out
Fixed W32 compare_filenames
Diffstat (limited to 'jnlib/stringhelp.c')
-rw-r--r--jnlib/stringhelp.c85
1 files changed, 55 insertions, 30 deletions
diff --git a/jnlib/stringhelp.c b/jnlib/stringhelp.c
index c1c1e451b..b1f6f73db 100644
--- a/jnlib/stringhelp.c
+++ b/jnlib/stringhelp.c
@@ -271,10 +271,10 @@ make_dirname(const char *filepath)
char *p;
if ( !(p=strrchr(filepath, '/')) )
- #ifdef HAVE_DRIVE_LETTERS
+#ifdef HAVE_DRIVE_LETTERS
if ( !(p=strrchr(filepath, '\\')) )
if ( !(p=strrchr(filepath, ':')) )
- #endif
+#endif
{
return jnlib_xstrdup(".");
}
@@ -296,42 +296,67 @@ make_dirname(const char *filepath)
char *
make_filename( const char *first_part, ... )
{
- va_list arg_ptr ;
- size_t n;
- const char *s;
- char *name, *home, *p;
-
- va_start( arg_ptr, first_part ) ;
- n = strlen(first_part)+1;
- while( (s=va_arg(arg_ptr, const char *)) )
- n += strlen(s) + 1;
- va_end(arg_ptr);
-
- home = NULL;
- if( *first_part == '~' && first_part[1] == '/'
- && (home = getenv("HOME")) && *home )
- n += strlen(home);
+ va_list arg_ptr ;
+ size_t n;
+ const char *s;
+ char *name, *home, *p;
+
+ va_start (arg_ptr, first_part);
+ n = strlen (first_part) + 1;
+ while ( (s = va_arg (arg_ptr, const char *)) )
+ n += strlen(s) + 1;
+ va_end(arg_ptr);
+
+ home = NULL;
+ if ( *first_part == '~' && first_part[1] == '/'
+ && (home = getenv("HOME")) && *home )
+ n += strlen (home);
+
+ name = jnlib_xmalloc (n);
+ p = (home
+ ? stpcpy (stpcpy (name,home), first_part + 1)
+ : stpcpy(name, first_part));
- name = jnlib_xmalloc(n);
- p = home ? stpcpy(stpcpy(name,home), first_part+1)
- : stpcpy(name, first_part);
- va_start( arg_ptr, first_part ) ;
- while( (s=va_arg(arg_ptr, const char *)) )
- p = stpcpy(stpcpy(p,"/"), s);
- va_end(arg_ptr);
+ va_start (arg_ptr, first_part) ;
+ while ( (s = va_arg(arg_ptr, const char *)) )
+ p = stpcpy (stpcpy (p,"/"), s);
+ va_end(arg_ptr);
- return name;
+#ifdef HAVE_DRIVE_LETTERS
+ /* We better avoid mixing slashes and backslashes and prefer
+ backslashes. There is usual no problem with mixing them, however
+ a very few W32 API calls can't grok plain slashes. Printing
+ filenames with mixed slashes also looks a bit strange. */
+ if (strchr (name, '\\'))
+ {
+ for (p=name; *p; p++)
+ if (*p == '/')
+ *p = '\\';
+ }
+#endif /*HAVE_DRIVE_LETTERS*/
+ return name;
}
int
-compare_filenames( const char *a, const char *b )
+compare_filenames (const char *a, const char *b)
{
- /* ? check whether this is an absolute filename and
- * resolve symlinks?
- */
+ /* ? check whether this is an absolute filename and resolve
+ symlinks? */
#ifdef HAVE_DRIVE_LETTERS
- return stricmp(a,b);
+ for ( ; *a && *b; a++, b++ )
+ {
+ if (*a != *b
+ && (toupper (*(const unsigned char*)a)
+ != toupper (*(const unsigned char*)b) )
+ && !((*a == '/' && *b == '\\') || (*a == '\\' && *b == '/')))
+ break;
+ }
+ if ((*a == '/' && *b == '\\') || (*a == '\\' && *b == '/'))
+ return 0;
+ else
+ return (toupper (*(const unsigned char*)a)
+ - toupper (*(const unsigned char*)b));
#else
return strcmp(a,b);
#endif