Fix broken recursive wildcard patch

darcs-hash:20051130153303-ac50b-3d0973badb50a98fe8038135a031a8ee14e4f894.gz
This commit is contained in:
axel 2005-12-01 01:33:03 +10:00
parent 2789da6a1a
commit 8ff66e718c

View file

@ -27,6 +27,13 @@
#include "reader.h" #include "reader.h"
#include "expand.h" #include "expand.h"
/**
This flag is set in the flags parameter of wildcard_expand if the
call is part of a recursiv wildcard search. It is used to make sure
that the contents of subdirectories are only searched once.
*/
#define WILDCARD_RECURSIVE 64
/** /**
The maximum length of a filename token. This is a fallback value, The maximum length of a filename token. This is a fallback value,
an attempt to find the true value using patchconf is always made. an attempt to find the true value using patchconf is always made.
@ -80,20 +87,29 @@ static int wildcard_match2( const wchar_t *str,
{ {
/* Ignore hidden file */ /* Ignore hidden file */
if( is_first && *str == L'.' ) if( is_first && *str == L'.' )
{
return 0; return 0;
}
/* Try all submatches */ /* Try all submatches */
do do
{ {
if( wildcard_match2( str, wc+1, 0 ) ) if( wildcard_match2( str, wc+1, 0 ) )
return 1; return 1;
} }
while( *(str++) != 0 ); while( *(str++) != 0 );
return 0; return 0;
} }
if( *wc == ANY_CHAR ) if( *wc == ANY_CHAR )
{
if( is_first && *str == L'.' )
{
return 0;
}
return wildcard_match2( str+1, wc+1, 0 ); return wildcard_match2( str+1, wc+1, 0 );
}
if( *wc == *str ) if( *wc == *str )
return wildcard_match2( str+1, wc+1, 0 ); return wildcard_match2( str+1, wc+1, 0 );
@ -379,6 +395,19 @@ int wildcard_expand( const wchar_t *wc,
*/ */
wc_recursive = wcschr( wc, ANY_STRING_RECURSIVE ); wc_recursive = wcschr( wc, ANY_STRING_RECURSIVE );
is_recursive = ( wc_recursive && (!wc_end || wc_recursive < wc_end)); is_recursive = ( wc_recursive && (!wc_end || wc_recursive < wc_end));
/*
This makes sure that the base
directory of the recursive search is
also searched for matching files.
*/
if( is_recursive && (wc_end==(wc+1)) && !(flags & WILDCARD_RECURSIVE ) )
{
wildcard_expand( wc_end + 1,
base_dir,
flags,
out );
}
if( flags & ACCEPT_INCOMPLETE ) if( flags & ACCEPT_INCOMPLETE )
sb_init( &sb_desc ); sb_init( &sb_desc );
@ -430,7 +459,7 @@ int wildcard_expand( const wchar_t *wc,
else else
{ {
res = 1; res = 1;
al_push( out, wcsdup( base_dir ) ); al_push_check( out, wcsdup( base_dir ) );
} }
} }
else else
@ -459,7 +488,7 @@ int wildcard_expand( const wchar_t *wc,
L"", L"",
0, 0,
0 ) ) 0 ) )
{ {
if( test_flags( long_name, flags ) ) if( test_flags( long_name, flags ) )
{ {
get_desc( long_name, get_desc( long_name,
@ -483,7 +512,7 @@ int wildcard_expand( const wchar_t *wc,
{ {
wchar_t *long_name = make_path( base_dir, name ); wchar_t *long_name = make_path( base_dir, name );
al_push( out, long_name ); al_push_check( out, long_name );
res = 1; res = 1;
} }
} }
@ -494,10 +523,9 @@ int wildcard_expand( const wchar_t *wc,
else else
{ {
/* /*
Wilcard segment is not the last segment. Wilcard segment is not the last segment. Recursively call
Recursively call wildcard_expand for all matching subdirectories. wildcard_expand for all matching subdirectories.
*/ */
/* /*
wc_str is the part of the wildcarded string from the wc_str is the part of the wildcarded string from the
@ -506,7 +534,8 @@ int wildcard_expand( const wchar_t *wc,
wchar_t *wc_str; wchar_t *wc_str;
/* /*
new_dir is a scratch area containing the full path to a file/directory we are iterating over new_dir is a scratch area containing the full path to a
file/directory we are iterating over
*/ */
wchar_t *new_dir; wchar_t *new_dir;
@ -583,7 +612,7 @@ int wildcard_expand( const wchar_t *wc,
if( dir_str ) if( dir_str )
{ {
stat_res= stat( dir_str, &buf ); stat_res = stat( dir_str, &buf );
free( dir_str ); free( dir_str );
if( !stat_res ) if( !stat_res )
@ -603,6 +632,7 @@ int wildcard_expand( const wchar_t *wc,
new_dir, new_dir,
flags, flags,
out ); out );
} }
/* /*
@ -612,7 +642,7 @@ int wildcard_expand( const wchar_t *wc,
{ {
res |= wildcard_expand( wcschr( wc, ANY_STRING_RECURSIVE ), res |= wildcard_expand( wcschr( wc, ANY_STRING_RECURSIVE ),
new_dir, new_dir,
flags, flags | WILDCARD_RECURSIVE,
out ); out );
} }
} }
@ -633,3 +663,18 @@ int wildcard_expand( const wchar_t *wc,
return res; return res;
} }
void al_push_check( array_list_t *l, const wchar_t *new )
{
int i;
for( i = 0; i < al_get_count(l); i++ )
{
if( !wcscmp( al_get(l, i), new ) )
{
free( new );
return;
}
}
al_push( l, new );
}