[svn.haxx.se] · SVN Dev · SVN Users · SVN Org · TSVN Dev · TSVN Users · Subclipse Dev · Subclipse Users · this month's index

Re: svn commit: r34963 - trunk/subversion/libsvn_subr

From: Julian Foad <julianfoad_at_btopenworld.com>
Date: Wed, 07 Jan 2009 17:38:55 +0000

On Wed, 2009-01-07 at 18:18 +0100, Stefan Küng wrote:
> Julian Foad wrote:
> > On Mon, 2008-12-29 at 09:09 -0800, Stefan Kueng wrote:
> >> Author: steveking
> >> Date: Mon Dec 29 09:09:17 2008
> >> New Revision: 34963
> >>
> >> Log:
> >> Fix bug in svn_path_is_canonical() where Windows UNC paths were always
> >> considered non-canonical.
> >>
> >> * subversion/libsvn_subr/dirent_uri.c
> >> (svn_uri_is_canonical): skip the second '/' of an UNC path.
> >>
> >> Modified:
> >> trunk/subversion/libsvn_subr/dirent_uri.c
> >>
> >> Modified: trunk/subversion/libsvn_subr/dirent_uri.c
> >> URL: http://svn.collab.net/viewvc/svn/trunk/subversion/libsvn_subr/dirent_uri.c?pathrev=34963&r1=34962&r2=34963
> >> ==============================================================================
> >> --- trunk/subversion/libsvn_subr/dirent_uri.c Sun Dec 28 12:03:46 2008 (r34962)
> >> +++ trunk/subversion/libsvn_subr/dirent_uri.c Mon Dec 29 09:09:17 2008 (r34963)
> >> @@ -1140,6 +1140,9 @@ svn_uri_is_canonical(const char *uri)
> >> ! (*(ptr+1) >= 'A' && *(ptr+1) <= 'Z') &&
> >> *(ptr+2) == ':')
> >> return FALSE;
> >> + /* if this is an UNC path, we have two '/' here */
> >> + if (*(ptr+1) == '/')
> >> + ptr++;
> >> }
> >> #endif /* WIN32 or Cygwin */
> >
> > This allows an extra slash in that position for all URIs when running on
> > Windows. Shouldn't this extra check be conditional on "if (strncmp(uri,
> > "file:", 5) == 0"?
>
> But then plain UNC paths wouldn't work, e.g. //servername/folder/file
>
> Maybe the svn_path_is_canonical() should differ between paths and urls?

This function is svn_uri_is_canonical(), not svn_path_is_canonical().

Ugh: svn_path_is_canonical() just calls svn_path_is_canonical(). What's
that all about?

There was a TO-DO item talked about before Christmas, something like
"finish or revert the new dirent/URI APIs". Is this an unfinished part
of that?

- Julian

------------------------------------------------------
http://subversion.tigris.org/ds/viewMessage.do?dsForumId=462&dsMessageId=1010178
Received on 2009-01-07 18:39:30 CET

This is an archived mail posted to the Subversion Dev mailing list.

This site is subject to the Apache Privacy Policy and the Apache Public Forum Archive Policy.