mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-14 05:53:59 +00:00
Switch from std::set to std::map in parse_util.cpp
This commit is contained in:
parent
fec0415d4e
commit
6f45832aed
1 changed files with 37 additions and 45 deletions
|
@ -55,18 +55,11 @@
|
||||||
struct autoload_function_t
|
struct autoload_function_t
|
||||||
{
|
{
|
||||||
bool is_placeholder; //whether we are a placeholder that stands in for "no such function"
|
bool is_placeholder; //whether we are a placeholder that stands in for "no such function"
|
||||||
wcstring name; //function name
|
|
||||||
time_t modification_time; // st_mtime
|
time_t modification_time; // st_mtime
|
||||||
time_t load_time; // when function was loaded
|
time_t load_time; // when function was loaded
|
||||||
|
|
||||||
struct compare_names
|
|
||||||
{
|
|
||||||
bool operator()(const autoload_function_t &a, const autoload_function_t &b) const {
|
|
||||||
return a.name < b.name;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
autoload_function_t(const wcstring &the_name) : is_placeholder(false), name(the_name), modification_time(0), load_time(0) { }
|
autoload_function_t() : is_placeholder(false), modification_time(0), load_time(0) { }
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -75,8 +68,8 @@ struct autoload_function_t
|
||||||
struct autoload_t
|
struct autoload_t
|
||||||
{
|
{
|
||||||
private:
|
private:
|
||||||
typedef std::set<autoload_function_t, autoload_function_t::compare_names> autoload_function_set_t;
|
typedef std::map<wcstring, autoload_function_t> autoload_functions_map_t;
|
||||||
autoload_function_set_t functions_set;
|
autoload_functions_map_t autoload_functions;
|
||||||
public:
|
public:
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -85,72 +78,73 @@ public:
|
||||||
*/
|
*/
|
||||||
std::set<wcstring> is_loading_set;
|
std::set<wcstring> is_loading_set;
|
||||||
|
|
||||||
bool is_loading(const wcstring &name) {
|
bool is_loading(const wcstring &name) const {
|
||||||
return is_loading_set.find(name) != is_loading_set.end();
|
return is_loading_set.find(name) != is_loading_set.end();
|
||||||
}
|
}
|
||||||
|
|
||||||
autoload_function_t *create_function_with_name(const wcstring &name)
|
autoload_function_t *create_function_with_name(const wcstring &name)
|
||||||
{
|
{
|
||||||
const autoload_function_t func(name);
|
return &autoload_functions[name];
|
||||||
autoload_function_set_t::iterator iter = functions_set.insert(func).first;
|
|
||||||
return const_cast<autoload_function_t *>(&*iter);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool remove_function_with_name(const wcstring &name)
|
bool remove_function_with_name(const wcstring &name)
|
||||||
{
|
{
|
||||||
const autoload_function_t func(name);
|
return autoload_functions.erase(name) > 0;
|
||||||
size_t numErased = functions_set.erase(func);
|
|
||||||
return numErased > 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
autoload_function_t *get_function_with_name(const wcstring &name)
|
autoload_function_t *get_function_with_name(const wcstring &name)
|
||||||
{
|
{
|
||||||
autoload_function_t *result = NULL;
|
autoload_function_t *result = NULL;
|
||||||
const autoload_function_t func(name);
|
autoload_functions_map_t::iterator iter = autoload_functions.find(name);
|
||||||
autoload_function_set_t::iterator iter = functions_set.find(func);
|
if (iter != autoload_functions.end())
|
||||||
if (iter != functions_set.end())
|
result = &iter->second;
|
||||||
result = const_cast<autoload_function_t *>(&*iter);
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
void remove_all_functions(void)
|
void remove_all_functions(void)
|
||||||
{
|
{
|
||||||
functions_set.clear();
|
autoload_functions.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t function_count(void) const
|
size_t function_count(void) const
|
||||||
{
|
{
|
||||||
return functions_set.size();
|
return autoload_functions.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Get the function least recently loaded, or NULL */
|
/* Get the name of the function that was least recently loaded, if it was loaded before cutoff_access. Return NULL if no function qualifies. */
|
||||||
autoload_function_t *get_lru_function(const wcstring &skip)
|
const wcstring *get_lru_function_name(const wcstring &skip, time_t cutoff_access) const
|
||||||
{
|
{
|
||||||
autoload_function_t *result = NULL;
|
const wcstring *resultName = NULL;
|
||||||
autoload_function_set_t::iterator iter;
|
const autoload_function_t *resultFunction = NULL;
|
||||||
for (iter = functions_set.begin(); iter != functions_set.end(); iter++)
|
autoload_functions_map_t::const_iterator iter;
|
||||||
|
for (iter = autoload_functions.begin(); iter != autoload_functions.end(); iter++)
|
||||||
{
|
{
|
||||||
/* Skip the skip */
|
/* Skip the skip */
|
||||||
if (iter->name == skip) continue;
|
if (iter->first == skip) continue;
|
||||||
|
|
||||||
/* Skip items that aren't real */
|
|
||||||
if (iter->is_placeholder) continue;
|
|
||||||
|
|
||||||
/* Skip items that are still loading */
|
/* Skip items that are still loading */
|
||||||
if (is_loading(iter->name)) continue;
|
if (is_loading(iter->first)) continue;
|
||||||
|
|
||||||
/* C++ makes all std::set iterators const because it wants to annoy us. */
|
/* Skip placeholder items */
|
||||||
if (result == NULL || iter->load_time < result->load_time)
|
if (iter->second.is_placeholder) continue;
|
||||||
result = const_cast<autoload_function_t *>(&*iter);
|
|
||||||
|
/* Check cutoff_access */
|
||||||
|
if (iter->second.load_time > cutoff_access) continue;
|
||||||
|
|
||||||
|
/* Remember this if it was used earlier */
|
||||||
|
if (resultFunction == NULL || iter->second.load_time < resultFunction->load_time) {
|
||||||
|
resultName = &iter->first;
|
||||||
|
resultFunction = &iter->second;
|
||||||
}
|
}
|
||||||
return result;
|
}
|
||||||
|
return resultName;
|
||||||
}
|
}
|
||||||
|
|
||||||
void apply_handler_to_nonplaceholder_function_names(void (*handler)(const wchar_t *cmd)) const
|
void apply_handler_to_nonplaceholder_function_names(void (*handler)(const wchar_t *cmd)) const
|
||||||
{
|
{
|
||||||
autoload_function_set_t::iterator iter;
|
autoload_functions_map_t::const_iterator iter;
|
||||||
for (iter = functions_set.begin(); iter != functions_set.end(); iter++)
|
for (iter = autoload_functions.begin(); iter != autoload_functions.end(); iter++)
|
||||||
handler(iter->name.c_str());
|
handler(iter->first.c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -785,12 +779,10 @@ static void parse_util_autounload( const wchar_t *path_var_name,
|
||||||
|
|
||||||
if( loaded.function_count() >= AUTOLOAD_MAX )
|
if( loaded.function_count() >= AUTOLOAD_MAX )
|
||||||
{
|
{
|
||||||
autoload_function_t *lru = loaded.get_lru_function(skip);
|
|
||||||
time_t cutoff_access = time(0) - AUTOLOAD_MIN_AGE;
|
time_t cutoff_access = time(0) - AUTOLOAD_MIN_AGE;
|
||||||
if (lru && lru->load_time < cutoff_access)
|
const wcstring *lru = loaded.get_lru_function_name(skip, cutoff_access);
|
||||||
{
|
if (lru)
|
||||||
parse_util_unload( lru->name.c_str(), path_var_name, on_load );
|
parse_util_unload( lru->c_str(), path_var_name, on_load );
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue