Excised some halloc

This commit is contained in:
ridiculousfish 2012-02-07 21:23:12 -08:00
parent 399c78fbf7
commit c0e783eb6e
6 changed files with 39 additions and 87 deletions

View file

@ -555,8 +555,6 @@ static int builtin_complete( parser_t &parser, wchar_t **argv )
{ {
recursion_level++; recursion_level++;
// comp = al_halloc( 0 );
complete( do_complete, comp ); complete( do_complete, comp );
for( size_t i=0; i< comp.size() ; i++ ) for( size_t i=0; i< comp.size() ; i++ )
@ -585,7 +583,6 @@ static int builtin_complete( parser_t &parser, wchar_t **argv )
} }
} }
// halloc_free( comp );
recursion_level--; recursion_level--;
} }

View file

@ -215,36 +215,10 @@ void completion_allocate(std::vector<completion_t> &completions, const wcstring
} }
/** /**
Destroys various structures used for tab-completion and free()s the memory used by them. The init function for the completion code. Does nothing.
*/
static void complete_destroy()
{
complete_entry_t *i=first_entry, *prev;
while( i )
{
prev = i;
i=i->next;
complete_free_entry( prev );
}
first_entry = 0;
completion_autoloader.unload_all();
}
/**
The init function for the completion code. Currently, all it really
does is make sure complete_destroy is called on exit.
*/ */
static void complete_init() static void complete_init()
{ {
static int is_init = 0;
if( !is_init )
{
is_init = 1;
halloc_register_function_void( global_context, &complete_destroy );
}
} }
/** /**

13
env.cpp
View file

@ -769,15 +769,12 @@ int env_set( const wchar_t *key,
if( val && contains( key, L"PWD", L"HOME" ) ) if( val && contains( key, L"PWD", L"HOME" ) )
{ {
void *context = halloc( 0, 0 ); /* Canoncalize our path; if it changes, recurse and try again. */
const wchar_t *val_canonical = path_make_canonical( context, val ); wcstring val_canonical = val;
if( wcscmp( val_canonical, val ) ) path_make_canonical(val_canonical);
{ if (val != val_canonical) {
int res = env_set( key, val_canonical, var_mode ); return env_set( key, val_canonical.c_str(), var_mode );
halloc_free( context );
return res;
} }
halloc_free( context );
} }
if( (var_mode & ENV_USER ) && is_read_only(key) ) if( (var_mode & ENV_USER ) && is_read_only(key) )

View file

@ -752,18 +752,13 @@ static void test_path()
{ {
say( L"Testing path functions" ); say( L"Testing path functions" );
void *context = halloc( 0, 0 ); wcstring path = L"//foo//////bar/";
wcstring canon = path;
path_make_canonical(canon);
wchar_t *can = path_make_canonical( context, L"//foo//////bar/" ); if( canon != L"/foo/bar" ) )
if( wcscmp( can, L"/foo/bar" ) )
{ {
err( L"Bug in canonical PATH code" ); err( L"Bug in canonical PATH code" );
} }
halloc_free( context );
} }

View file

@ -514,38 +514,30 @@ bool path_get_config(wcstring &path)
} }
wchar_t *path_make_canonical( void *context, const wchar_t *path ) static void replace_all(wcstring &str, const wchar_t *needle, const wchar_t *replacement)
{ {
wchar_t *res = halloc_wcsdup( context, path ); size_t needle_len = wcslen(needle);
wchar_t *in, *out; size_t offset = 0;
while((offset = str.find(needle, offset)) != wcstring::npos)
in = out = res;
while( *in )
{ {
if( *in == L'/' ) str.replace(offset, needle_len, replacement);
{ offset += needle_len;
while( *(in+1) == L'/' )
{
in++;
} }
} }
*out = *in;
out++; void path_make_canonical( wcstring &path )
in++;
}
while( 1 )
{ {
if( out == res )
/* Remove double slashes */
replace_all(path, L"//", L"/");
/* Remove trailing slashes */
size_t size = path.size();
while (size--) {
if (path.at(size) != L'/')
break; break;
if( *(out-1) != L'/' )
break;
out--;
} }
*out = 0; /* Now size is either -1 (if the entire string was slashes) or is the index of the last non-slash character. Either way this will set it to the correct size. */
path.resize(size+1);
return res;
} }

9
path.h
View file

@ -57,13 +57,10 @@ bool path_can_get_cdpath(const wcstring &in);
bool path_get_cdpath_string(const wcstring &in, wcstring &out, const env_vars &vars); bool path_get_cdpath_string(const wcstring &in, wcstring &out, const env_vars &vars);
/** /**
Remove doulbe slashes and trailing slashes from a path, Remove double slashes and trailing slashes from a path,
e.g. transform foo//bar/ into foo/bar. e.g. transform foo//bar/ into foo/bar. The string is modified in-place.
The returned string is allocated using the specified halloc
context.
*/ */
wchar_t *path_make_canonical( void *context, const wchar_t *path ); void path_make_canonical( wcstring &path );
#endif #endif