patch 9.1.1720: using gettimeofday() for parsing OSC responses
Problem: Using gettimeofday() for parsing OSC responses Solution: Use ELAPSED_ macros instead (Foxe Chen). closes: #18165 Signed-off-by: Foxe Chen <chen.foxe@gmail.com> Signed-off-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
committed by
Christian Brabandt
parent
2035c74574
commit
6278f1a10a
@ -1290,19 +1290,6 @@ typedef struct
|
||||
#endif
|
||||
} tasave_T;
|
||||
|
||||
// Holds state for current OSC response.
|
||||
typedef struct
|
||||
{
|
||||
int processing; // If we are in the middle of an OSC response
|
||||
char_u start_char; // First char in the OSC response
|
||||
garray_T buf; // Buffer holding the OSC response, to be
|
||||
// placed in the "v:termosc" vim var.
|
||||
|
||||
struct timeval start; // Set at the beginning of an OSC response.
|
||||
// Used to timeout after a set amount of
|
||||
// time.
|
||||
} oscstate_T;
|
||||
|
||||
/*
|
||||
* Used for conversion of terminal I/O and script files.
|
||||
*/
|
||||
|
30
src/term.c
30
src/term.c
@ -104,6 +104,21 @@ typedef struct {
|
||||
time_t tr_start; // when request was sent, -1 for never
|
||||
} termrequest_T;
|
||||
|
||||
// Holds state for current OSC response.
|
||||
typedef struct
|
||||
{
|
||||
int processing; // If we are in the middle of an OSC response
|
||||
char_u start_char; // First char in the OSC response
|
||||
garray_T buf; // Buffer holding the OSC response, to be
|
||||
// placed in the "v:termosc" vim var.
|
||||
|
||||
#ifdef ELAPSED_FUNC
|
||||
elapsed_T start_tv; // Set at the beginning of an OSC response.
|
||||
// Used to timeout after a set amount of
|
||||
// time.
|
||||
#endif
|
||||
} oscstate_T;
|
||||
|
||||
#define TERMREQUEST_INIT {STATUS_GET, -1}
|
||||
|
||||
// Request Terminal Version status:
|
||||
@ -5690,7 +5705,6 @@ static oscstate_T osc_state;
|
||||
static int
|
||||
handle_osc(char_u *tp, int len, char_u *key_name, int *slen)
|
||||
{
|
||||
struct timeval now;
|
||||
char_u last_char;
|
||||
|
||||
if (!osc_state.processing)
|
||||
@ -5712,8 +5726,9 @@ handle_osc(char_u *tp, int len, char_u *key_name, int *slen)
|
||||
// To handle this, keep reading data in and out of the typeahead
|
||||
// buffer until we read an OSC terminator or timeout.
|
||||
ga_init2(&osc_state.buf, 1, 1024);
|
||||
gettimeofday(&osc_state.start, NULL);
|
||||
|
||||
#ifdef ELAPSED_FUNC
|
||||
ELAPSED_INIT(osc_state.start_tv);
|
||||
#endif
|
||||
osc_state.processing = TRUE;
|
||||
osc_state.start_char = tp[0];
|
||||
last_char = 0;
|
||||
@ -5748,12 +5763,8 @@ handle_osc(char_u *tp, int len, char_u *key_name, int *slen)
|
||||
return OK;
|
||||
}
|
||||
|
||||
// Check if timeout has been reached
|
||||
gettimeofday(&now, NULL);
|
||||
|
||||
if ((now.tv_sec * 1000000 + now.tv_usec) -
|
||||
(osc_state.start.tv_sec * 1000000 + osc_state.start.tv_usec)
|
||||
>= p_ost * 1000)
|
||||
#ifdef ELAPSED_FUNC
|
||||
if (ELAPSED_FUNC(osc_state.start_tv) >= p_ost)
|
||||
{
|
||||
semsg(_(e_osc_response_timed_out), osc_state.buf.ga_len,
|
||||
osc_state.buf.ga_data);
|
||||
@ -5762,6 +5773,7 @@ handle_osc(char_u *tp, int len, char_u *key_name, int *slen)
|
||||
osc_state.processing = FALSE;
|
||||
return FAIL;
|
||||
}
|
||||
#endif
|
||||
|
||||
ga_concat(&osc_state.buf, tp);
|
||||
*slen = len; // Consume everything
|
||||
|
@ -724,6 +724,8 @@ static char *(features[]) =
|
||||
|
||||
static int included_patches[] =
|
||||
{ /* Add new patch number below this line */
|
||||
/**/
|
||||
1720,
|
||||
/**/
|
||||
1719,
|
||||
/**/
|
||||
|
Reference in New Issue
Block a user