mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-27 20:25:12 +00:00
Work towards getting function.h off of shared_ptr
This commit is contained in:
parent
977c585f8b
commit
86645b32e1
9 changed files with 40 additions and 44 deletions
16
builtin.cpp
16
builtin.cpp
|
@ -1086,7 +1086,8 @@ static int builtin_generic( parser_t &parser, wchar_t **argv )
|
||||||
static void functions_def( const wcstring &name, wcstring &out )
|
static void functions_def( const wcstring &name, wcstring &out )
|
||||||
{
|
{
|
||||||
const wchar_t *desc = function_get_desc( name );
|
const wchar_t *desc = function_get_desc( name );
|
||||||
const wchar_t *def = function_get_definition(name);
|
wcstring def;
|
||||||
|
function_get_definition(name, &def);
|
||||||
|
|
||||||
event_t search(EVENT_ANY);
|
event_t search(EVENT_ANY);
|
||||||
|
|
||||||
|
@ -1169,11 +1170,10 @@ static void functions_def( const wcstring &name, wcstring &out )
|
||||||
|
|
||||||
|
|
||||||
/* This forced tab is sort of crummy - not all functions start with a tab */
|
/* This forced tab is sort of crummy - not all functions start with a tab */
|
||||||
append_format( out, L"\n\t%ls", def);
|
append_format( out, L"\n\t%ls", def.c_str());
|
||||||
|
|
||||||
/* Append a newline before the 'end', unless there already is one there */
|
/* Append a newline before the 'end', unless there already is one there */
|
||||||
size_t deflen = wcslen(def);
|
if (! string_suffixes_string(L"\n", def)) {
|
||||||
if (deflen == 0 || def[deflen-1] != L'\n') {
|
|
||||||
out.push_back(L'\n');
|
out.push_back(L'\n');
|
||||||
}
|
}
|
||||||
out.append(L"end\n");
|
out.append(L"end\n");
|
||||||
|
@ -3733,10 +3733,14 @@ void builtin_get_names(std::vector<completion_t> &list) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const wchar_t *builtin_get_desc( const wcstring &name )
|
wcstring builtin_get_desc( const wcstring &name )
|
||||||
{
|
{
|
||||||
|
wcstring result;
|
||||||
const builtin_data_t *builtin = builtin_lookup(name);
|
const builtin_data_t *builtin = builtin_lookup(name);
|
||||||
return builtin ? _(builtin->desc) : NULL;
|
if (builtin) {
|
||||||
|
result = _(builtin->desc);
|
||||||
|
}
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
void builtin_push_io( parser_t &parser, int in )
|
void builtin_push_io( parser_t &parser, int in )
|
||||||
|
|
|
@ -155,9 +155,9 @@ void builtin_pop_io(parser_t &parser);
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Return a one-line description of the specified builtin. This is usually a truly constant string, so we should not wrap it in a wcstring.
|
Return a one-line description of the specified builtin.
|
||||||
*/
|
*/
|
||||||
const wchar_t *builtin_get_desc( const wcstring &b );
|
wcstring builtin_get_desc( const wcstring &b );
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
18
complete.cpp
18
complete.cpp
|
@ -832,7 +832,7 @@ int complete_is_valid_argument( const wchar_t *str,
|
||||||
static void complete_strings( std::vector<completion_t> &comp_out,
|
static void complete_strings( std::vector<completion_t> &comp_out,
|
||||||
const wcstring &wc_escaped,
|
const wcstring &wc_escaped,
|
||||||
const wchar_t *desc,
|
const wchar_t *desc,
|
||||||
const wchar_t *(*desc_func)(const wcstring &),
|
wcstring (*desc_func)(const wcstring &),
|
||||||
std::vector<completion_t> &possible_comp,
|
std::vector<completion_t> &possible_comp,
|
||||||
complete_flags_t flags )
|
complete_flags_t flags )
|
||||||
{
|
{
|
||||||
|
@ -981,16 +981,20 @@ void completer_t::complete_cmd_desc( const wcstring &str )
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Returns a description for the specified function
|
Returns a description for the specified function, or an empty string if none
|
||||||
*/
|
*/
|
||||||
static const wchar_t *complete_function_desc( const wcstring &fn )
|
static wcstring complete_function_desc( const wcstring &fn )
|
||||||
{
|
{
|
||||||
|
wcstring result;
|
||||||
|
|
||||||
const wchar_t *res = function_get_desc( fn );
|
const wchar_t *res = function_get_desc( fn );
|
||||||
|
if (res) {
|
||||||
|
result = res;
|
||||||
|
} else {
|
||||||
|
function_get_definition(fn, &result);
|
||||||
|
}
|
||||||
|
|
||||||
if( !res )
|
return result;
|
||||||
res = function_get_definition( fn );
|
|
||||||
|
|
||||||
return res;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
7
exec.cpp
7
exec.cpp
|
@ -787,12 +787,13 @@ void exec( parser_t &parser, job_t *j )
|
||||||
*/
|
*/
|
||||||
|
|
||||||
signal_unblock();
|
signal_unblock();
|
||||||
const wchar_t * orig_def = function_get_definition( p->argv0() );
|
wcstring orig_def;
|
||||||
|
function_get_definition( p->argv0(), &orig_def );
|
||||||
|
|
||||||
// function_get_named_arguments may trigger autoload, which deallocates the orig_def.
|
// function_get_named_arguments may trigger autoload, which deallocates the orig_def.
|
||||||
// We should make function_get_definition return a wcstring (but how to handle NULL...)
|
// We should make function_get_definition return a wcstring (but how to handle NULL...)
|
||||||
if (orig_def)
|
if (! orig_def.empty())
|
||||||
def = wcsdup(orig_def);
|
def = wcsdup(orig_def.c_str());
|
||||||
|
|
||||||
wcstring_list_t named_arguments = function_get_named_arguments( p->argv0() );
|
wcstring_list_t named_arguments = function_get_named_arguments( p->argv0() );
|
||||||
shadows = function_get_shadows( p->argv0() );
|
shadows = function_get_shadows( p->argv0() );
|
||||||
|
|
|
@ -251,10 +251,13 @@ shared_ptr<function_info_t> function_get(const wcstring &name)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const wchar_t *function_get_definition( const wcstring &name )
|
bool function_get_definition( const wcstring &name, wcstring *out_definition )
|
||||||
{
|
{
|
||||||
shared_ptr<function_info_t> func = function_get(name);
|
shared_ptr<function_info_t> func = function_get(name);
|
||||||
return func ? func->definition.c_str() : NULL;
|
if (func && out_definition) {
|
||||||
|
out_definition->assign(func->definition);
|
||||||
|
}
|
||||||
|
return func != NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
wcstring_list_t function_get_named_arguments( const wcstring &name )
|
wcstring_list_t function_get_named_arguments( const wcstring &name )
|
||||||
|
|
10
function.h
10
function.h
|
@ -103,14 +103,10 @@ void function_add( const function_data_t &data, const parser_t &parser );
|
||||||
void function_remove( const wcstring &name );
|
void function_remove( const wcstring &name );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Gets a function by name.
|
Returns by reference the definition of the function with the name \c name.
|
||||||
|
Returns true if successful, false if no function with the given name exists.
|
||||||
*/
|
*/
|
||||||
shared_ptr<function_info_t> function_get(const wcstring &name);
|
bool function_get_definition( const wcstring &name, wcstring *out_definition );
|
||||||
|
|
||||||
/**
|
|
||||||
Returns the definition of the function with the name \c name.
|
|
||||||
*/
|
|
||||||
const wchar_t *function_get_definition( const wcstring &name );
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Returns the description of the function with the name \c name.
|
Returns the description of the function with the name \c name.
|
||||||
|
|
12
history.cpp
12
history.cpp
|
@ -136,18 +136,6 @@ static void escape_yaml(std::string &str);
|
||||||
/** Undoes escape_yaml */
|
/** Undoes escape_yaml */
|
||||||
static void unescape_yaml(std::string &str);
|
static void unescape_yaml(std::string &str);
|
||||||
|
|
||||||
/* Custom deleter for our shared_ptr */
|
|
||||||
class history_item_data_deleter_t {
|
|
||||||
private:
|
|
||||||
const bool free_it;
|
|
||||||
public:
|
|
||||||
history_item_data_deleter_t(bool flag) : free_it(flag) { }
|
|
||||||
void operator()(const wchar_t *data) {
|
|
||||||
if (free_it)
|
|
||||||
free((void *)data);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
/* We can merge two items if they are the same command. We use the more recent timestamp and the longer list of required paths. */
|
/* We can merge two items if they are the same command. We use the more recent timestamp and the longer list of required paths. */
|
||||||
bool history_item_t::merge(const history_item_t &item)
|
bool history_item_t::merge(const history_item_t &item)
|
||||||
{
|
{
|
||||||
|
|
|
@ -204,7 +204,7 @@ static bool wildcard_complete_internal(const wcstring &orig,
|
||||||
const wchar_t *wc,
|
const wchar_t *wc,
|
||||||
bool is_first,
|
bool is_first,
|
||||||
const wchar_t *desc,
|
const wchar_t *desc,
|
||||||
const wchar_t *(*desc_func)(const wcstring &),
|
wcstring (*desc_func)(const wcstring &),
|
||||||
std::vector<completion_t> &out,
|
std::vector<completion_t> &out,
|
||||||
int flags )
|
int flags )
|
||||||
{
|
{
|
||||||
|
@ -245,8 +245,8 @@ static bool wildcard_complete_internal(const wcstring &orig,
|
||||||
it. If it returns something, use that as the
|
it. If it returns something, use that as the
|
||||||
description.
|
description.
|
||||||
*/
|
*/
|
||||||
const wchar_t *func_desc = desc_func( orig );
|
wcstring func_desc = desc_func( orig );
|
||||||
if( func_desc )
|
if (! func_desc.empty())
|
||||||
out_desc = func_desc;
|
out_desc = func_desc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -300,7 +300,7 @@ static bool wildcard_complete_internal(const wcstring &orig,
|
||||||
bool wildcard_complete(const wcstring &str,
|
bool wildcard_complete(const wcstring &str,
|
||||||
const wchar_t *wc,
|
const wchar_t *wc,
|
||||||
const wchar_t *desc,
|
const wchar_t *desc,
|
||||||
const wchar_t *(*desc_func)(const wcstring &),
|
wcstring (*desc_func)(const wcstring &),
|
||||||
std::vector<completion_t> &out,
|
std::vector<completion_t> &out,
|
||||||
int flags )
|
int flags )
|
||||||
{
|
{
|
||||||
|
|
|
@ -89,7 +89,7 @@ int wildcard_has( const wchar_t *str, int internal );
|
||||||
bool wildcard_complete(const wcstring &str,
|
bool wildcard_complete(const wcstring &str,
|
||||||
const wchar_t *wc,
|
const wchar_t *wc,
|
||||||
const wchar_t *desc,
|
const wchar_t *desc,
|
||||||
const wchar_t *(*desc_func)(const wcstring &),
|
wcstring (*desc_func)(const wcstring &),
|
||||||
std::vector<completion_t> &out,
|
std::vector<completion_t> &out,
|
||||||
expand_flags_t flags );
|
expand_flags_t flags );
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue