mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-13 21:44:16 +00:00
Removed halloc from input.cpp
This commit is contained in:
parent
8a2737566c
commit
e6f7912a25
3 changed files with 35 additions and 61 deletions
2
env.cpp
2
env.cpp
|
@ -57,8 +57,6 @@
|
||||||
#include "input_common.h"
|
#include "input_common.h"
|
||||||
#include "event.h"
|
#include "event.h"
|
||||||
#include "path.h"
|
#include "path.h"
|
||||||
#include "halloc.h"
|
|
||||||
#include "halloc_util.h"
|
|
||||||
|
|
||||||
#include "complete.h"
|
#include "complete.h"
|
||||||
|
|
||||||
|
|
93
input.cpp
93
input.cpp
|
@ -69,18 +69,7 @@
|
||||||
#include "intern.h"
|
#include "intern.h"
|
||||||
#include "halloc.h"
|
#include "halloc.h"
|
||||||
#include "halloc_util.h"
|
#include "halloc_util.h"
|
||||||
|
#include <vector>
|
||||||
/**
|
|
||||||
Add a new terminfo mapping
|
|
||||||
*/
|
|
||||||
#define TERMINFO_ADD(key) \
|
|
||||||
{ \
|
|
||||||
terminfo_mapping_t *m = (terminfo_mapping_t *)halloc( terminfo_mappings, sizeof( terminfo_mapping_t ) ); \
|
|
||||||
m->name = halloc_wcsdup( terminfo_mappings, (L ## #key)+4 ); \
|
|
||||||
m->seq = key; \
|
|
||||||
al_push( terminfo_mappings, m ); \
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Struct representing a keybinding. Returned by input_get_mappings.
|
Struct representing a keybinding. Returned by input_get_mappings.
|
||||||
|
@ -97,13 +86,12 @@ struct input_mapping_t
|
||||||
/**
|
/**
|
||||||
A struct representing the mapping from a terminfo key name to a terminfo character sequence
|
A struct representing the mapping from a terminfo key name to a terminfo character sequence
|
||||||
*/
|
*/
|
||||||
typedef struct
|
struct terminfo_mapping_t
|
||||||
{
|
{
|
||||||
const wchar_t *name; /**< Name of key */
|
const wchar_t *name; /**< Name of key */
|
||||||
const char *seq; /**< Character sequence generated on keypress */
|
const char *seq; /**< Character sequence generated on keypress. Constant string. */
|
||||||
|
|
||||||
}
|
};
|
||||||
terminfo_mapping_t;
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -228,15 +216,26 @@ static const wchar_t code_arr[] =
|
||||||
}
|
}
|
||||||
;
|
;
|
||||||
|
|
||||||
/**
|
/** Mappings for the current input mode */
|
||||||
Mappings for the current input mode
|
static std::vector<input_mapping_t> mapping_list;
|
||||||
*/
|
|
||||||
std::vector<input_mapping_t> mapping_list;
|
/* Terminfo map list */
|
||||||
|
static std::vector<terminfo_mapping_t> terminfo_mappings;
|
||||||
|
|
||||||
|
/** Add a new terminfo mapping */
|
||||||
|
static inline void terminfo_add(const wchar_t *name, const char *seq)
|
||||||
|
{
|
||||||
|
terminfo_mapping_t mapping = {name, seq};
|
||||||
|
terminfo_mappings.push_back(mapping);
|
||||||
|
}
|
||||||
|
#define TERMINFO_ADD(key) do { terminfo_add((L ## #key)+4, key); } while (0)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
List of all terminfo mappings
|
List of all terminfo mappings
|
||||||
*/
|
*/
|
||||||
static array_list_t *terminfo_mappings = 0;
|
static std::vector<terminfo_mapping_t> mappings;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -248,10 +247,7 @@ static int is_init = 0;
|
||||||
Initialize terminfo.
|
Initialize terminfo.
|
||||||
*/
|
*/
|
||||||
static void input_terminfo_init();
|
static void input_terminfo_init();
|
||||||
/**
|
|
||||||
Deallocate memory used by terminfo. Or at least try to. Terminfo leaks.
|
|
||||||
*/
|
|
||||||
static void input_terminfo_destroy();
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Returns the function description for the given function code.
|
Returns the function description for the given function code.
|
||||||
|
@ -361,9 +357,6 @@ void input_destroy()
|
||||||
{
|
{
|
||||||
debug( 0, _(L"Error while closing terminfo") );
|
debug( 0, _(L"Error while closing terminfo") );
|
||||||
}
|
}
|
||||||
|
|
||||||
input_terminfo_destroy();
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -581,9 +574,6 @@ bool input_mapping_get( const wcstring &sequence, wcstring &cmd )
|
||||||
*/
|
*/
|
||||||
static void input_terminfo_init()
|
static void input_terminfo_init()
|
||||||
{
|
{
|
||||||
terminfo_mappings = al_halloc( 0 );
|
|
||||||
|
|
||||||
|
|
||||||
TERMINFO_ADD(key_a1);
|
TERMINFO_ADD(key_a1);
|
||||||
TERMINFO_ADD(key_a3);
|
TERMINFO_ADD(key_a3);
|
||||||
TERMINFO_ADD(key_b2);
|
TERMINFO_ADD(key_b2);
|
||||||
|
@ -742,32 +732,21 @@ static void input_terminfo_init()
|
||||||
TERMINFO_ADD(key_up);
|
TERMINFO_ADD(key_up);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void input_terminfo_destroy()
|
|
||||||
{
|
|
||||||
|
|
||||||
if( terminfo_mappings )
|
|
||||||
{
|
|
||||||
halloc_free( terminfo_mappings );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const wchar_t *input_terminfo_get_sequence( const wchar_t *name )
|
const wchar_t *input_terminfo_get_sequence( const wchar_t *name )
|
||||||
{
|
{
|
||||||
const char *res = 0;
|
const char *res = 0;
|
||||||
int i;
|
|
||||||
static string_buffer_t *buff = 0;
|
static string_buffer_t *buff = 0;
|
||||||
int err = ENOENT;
|
int err = ENOENT;
|
||||||
|
|
||||||
CHECK( name, 0 );
|
CHECK( name, 0 );
|
||||||
input_init();
|
input_init();
|
||||||
|
|
||||||
for( i=0; i<al_get_count( terminfo_mappings ); i++ )
|
for( size_t i=0; i<terminfo_mappings.size(); i++ )
|
||||||
{
|
{
|
||||||
terminfo_mapping_t *m = (terminfo_mapping_t *)al_get( terminfo_mappings, i );
|
const terminfo_mapping_t &m = terminfo_mappings.at(i);
|
||||||
|
if( !wcscmp( name, m.name ) )
|
||||||
if( !wcscmp( name, m->name ) )
|
|
||||||
{
|
{
|
||||||
res = m->seq;
|
res = m.seq;
|
||||||
err = EILSEQ;
|
err = EILSEQ;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -793,22 +772,20 @@ const wchar_t *input_terminfo_get_sequence( const wchar_t *name )
|
||||||
|
|
||||||
bool input_terminfo_get_name( const wcstring &seq, wcstring &name )
|
bool input_terminfo_get_name( const wcstring &seq, wcstring &name )
|
||||||
{
|
{
|
||||||
int i;
|
|
||||||
|
|
||||||
input_init();
|
input_init();
|
||||||
|
|
||||||
for( i=0; i<al_get_count( terminfo_mappings ); i++ )
|
for( size_t i=0; i<terminfo_mappings.size(); i++ )
|
||||||
{
|
{
|
||||||
terminfo_mapping_t *m = (terminfo_mapping_t *)al_get( terminfo_mappings, i );
|
terminfo_mapping_t &m = terminfo_mappings.at(i);
|
||||||
|
|
||||||
if( !m->seq )
|
if( !m.seq )
|
||||||
{
|
{
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
const wcstring map_buf = format_string(L"%s", m->seq);
|
const wcstring map_buf = format_string(L"%s", m.seq);
|
||||||
if (map_buf == seq) {
|
if (map_buf == seq) {
|
||||||
name = m->name;
|
name = m.name;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -819,19 +796,19 @@ bool input_terminfo_get_name( const wcstring &seq, wcstring &name )
|
||||||
wcstring_list_t input_terminfo_get_names( bool skip_null )
|
wcstring_list_t input_terminfo_get_names( bool skip_null )
|
||||||
{
|
{
|
||||||
wcstring_list_t result;
|
wcstring_list_t result;
|
||||||
result.reserve(al_get_count(terminfo_mappings));
|
result.reserve(terminfo_mappings.size());
|
||||||
|
|
||||||
input_init();
|
input_init();
|
||||||
|
|
||||||
for( int i=0; i<al_get_count( terminfo_mappings ); i++ )
|
for( size_t i=0; i<terminfo_mappings.size(); i++ )
|
||||||
{
|
{
|
||||||
terminfo_mapping_t *m = (terminfo_mapping_t *)al_get( terminfo_mappings, i );
|
terminfo_mapping_t &m = terminfo_mappings.at(i);
|
||||||
|
|
||||||
if( skip_null && !m->seq )
|
if( skip_null && !m.seq )
|
||||||
{
|
{
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
result.push_back(wcstring(m->name));
|
result.push_back(wcstring(m.name));
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
1
kill.cpp
1
kill.cpp
|
@ -29,7 +29,6 @@
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
#include "env.h"
|
#include "env.h"
|
||||||
#include "exec.h"
|
#include "exec.h"
|
||||||
#include "halloc.h"
|
|
||||||
#include "path.h"
|
#include "path.h"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Reference in a new issue