kopia lustrzana https://github.com/Hamlib/Hamlib
Fix issue where Hamlib attempts to use memory returned by setlocale() after being freed.
rodzic
9570d9963b
commit
0fd094f476
|
@ -23,6 +23,9 @@
|
||||||
#define _NUM_STDIO_H 1
|
#define _NUM_STDIO_H 1
|
||||||
|
|
||||||
#include <locale.h>
|
#include <locale.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <assert.h>
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This header file is internal to Hamlib and its backends,
|
* This header file is internal to Hamlib and its backends,
|
||||||
|
@ -36,27 +39,42 @@
|
||||||
#define num_sscanf(a...) \
|
#define num_sscanf(a...) \
|
||||||
({ int __ret; char *__savedlocale; \
|
({ int __ret; char *__savedlocale; \
|
||||||
__savedlocale = setlocale(LC_NUMERIC, NULL); \
|
__savedlocale = setlocale(LC_NUMERIC, NULL); \
|
||||||
|
if (__savedlocale != NULL) { \
|
||||||
|
__savedlocale = strdup(__savedlocale); \
|
||||||
|
assert(__savedlocale != NULL); \
|
||||||
|
} \
|
||||||
setlocale(LC_NUMERIC, "C"); \
|
setlocale(LC_NUMERIC, "C"); \
|
||||||
__ret = sscanf(a); \
|
__ret = sscanf(a); \
|
||||||
setlocale(LC_NUMERIC, __savedlocale); \
|
setlocale(LC_NUMERIC, __savedlocale); \
|
||||||
|
if (__savedlocale != NULL) free(__savedlocale); \
|
||||||
__ret; \
|
__ret; \
|
||||||
})
|
})
|
||||||
|
|
||||||
#define num_sprintf(s, a...) \
|
#define num_sprintf(s, a...) \
|
||||||
({ int __ret; char *__savedlocale; \
|
({ int __ret; char *__savedlocale; \
|
||||||
__savedlocale = setlocale(LC_NUMERIC, NULL); \
|
__savedlocale = setlocale(LC_NUMERIC, NULL); \
|
||||||
|
if (__savedlocale != NULL) { \
|
||||||
|
__savedlocale = strdup(__savedlocale); \
|
||||||
|
assert(__savedlocale != NULL); \
|
||||||
|
} \
|
||||||
setlocale(LC_NUMERIC, "C"); \
|
setlocale(LC_NUMERIC, "C"); \
|
||||||
__ret = sprintf(s, a); \
|
__ret = sprintf(s, a); \
|
||||||
setlocale(LC_NUMERIC, __savedlocale); \
|
setlocale(LC_NUMERIC, __savedlocale); \
|
||||||
|
if (__savedlocale != NULL) free(__savedlocale); \
|
||||||
__ret; \
|
__ret; \
|
||||||
})
|
})
|
||||||
|
|
||||||
#define num_snprintf(s, n, a...) \
|
#define num_snprintf(s, n, a...) \
|
||||||
({ int __ret; char *__savedlocale; \
|
({ int __ret; char *__savedlocale; \
|
||||||
__savedlocale = setlocale(LC_NUMERIC, NULL); \
|
__savedlocale = setlocale(LC_NUMERIC, NULL); \
|
||||||
|
if (__savedlocale != NULL) { \
|
||||||
|
__savedlocale = strdup(__savedlocale); \
|
||||||
|
assert(__savedlocale != NULL); \
|
||||||
|
} \
|
||||||
setlocale(LC_NUMERIC, "C"); \
|
setlocale(LC_NUMERIC, "C"); \
|
||||||
__ret = snprintf(s, n, a); \
|
__ret = snprintf(s, n, a); \
|
||||||
setlocale(LC_NUMERIC, __savedlocale); \
|
setlocale(LC_NUMERIC, __savedlocale); \
|
||||||
|
if (__savedlocale != NULL) free(__savedlocale); \
|
||||||
__ret; \
|
__ret; \
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
Ładowanie…
Reference in New Issue