forked from aniani/vim
patch 8.2.3673: crash when allocating signal stack fails
Problem: Crash when allocating signal stack fails. Solution: Only using sourcing info when available. (closes #9215)
This commit is contained in:
parent
71b36206be
commit
0bd8d05638
@ -288,6 +288,7 @@ EXTERN int msg_no_more INIT(= FALSE); // don't use more prompt, truncate
|
||||
* Current context is at ga_len - 1.
|
||||
*/
|
||||
EXTERN garray_T exestack INIT5(0, 0, sizeof(estack_T), 50, NULL);
|
||||
#define HAVE_SOURCING_INFO (exestack.ga_data != NULL && exestack.ga_len > 0)
|
||||
// name of error message source
|
||||
#define SOURCING_NAME (((estack_T *)exestack.ga_data)[exestack.ga_len - 1].es_name)
|
||||
// line number in the message source or zero
|
||||
|
@ -446,7 +446,7 @@ reset_last_sourcing(void)
|
||||
static int
|
||||
other_sourcing_name(void)
|
||||
{
|
||||
if (SOURCING_NAME != NULL)
|
||||
if (HAVE_SOURCING_INFO && SOURCING_NAME != NULL)
|
||||
{
|
||||
if (last_sourcing_name != NULL)
|
||||
return STRCMP(SOURCING_NAME, last_sourcing_name) != 0;
|
||||
@ -465,7 +465,7 @@ get_emsg_source(void)
|
||||
{
|
||||
char_u *Buf, *p;
|
||||
|
||||
if (SOURCING_NAME != NULL && other_sourcing_name())
|
||||
if (HAVE_SOURCING_INFO && SOURCING_NAME != NULL && other_sourcing_name())
|
||||
{
|
||||
char_u *sname = estack_sfile(ESTACK_NONE);
|
||||
char_u *tofree = sname;
|
||||
|
@ -757,6 +757,8 @@ static char *(features[]) =
|
||||
|
||||
static int included_patches[] =
|
||||
{ /* Add new patch number below this line */
|
||||
/**/
|
||||
3673,
|
||||
/**/
|
||||
3672,
|
||||
/**/
|
||||
|
Loading…
x
Reference in New Issue
Block a user