Fix compilation with clang
This commit is contained in:
parent
0797f159ad
commit
a568f73e77
@ -129,10 +129,17 @@ typedef unsigned int index_type;
|
|||||||
return result; \
|
return result; \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef __clang__
|
||||||
|
#define START_ALLOW_CASE_RANGE _Pragma("clang diagnostic push") _Pragma("clang diagnostic ignored \"-Wpedantic\"")
|
||||||
|
#define END_ALLOW_CASE_RANGE _Pragma("clang diagnostic pop")
|
||||||
|
#define ALLOW_UNUSED_RESULT _Pragma("clang diagnostic push") _Pragma("clang diagnostic ignored \"-Wunused-result\"")
|
||||||
|
#define END_ALLOW_UNUSED_RESULT _Pragma("clang diagnostic pop")
|
||||||
|
#else
|
||||||
#define START_ALLOW_CASE_RANGE _Pragma("GCC diagnostic ignored \"-Wpedantic\"")
|
#define START_ALLOW_CASE_RANGE _Pragma("GCC diagnostic ignored \"-Wpedantic\"")
|
||||||
#define END_ALLOW_CASE_RANGE _Pragma("GCC diagnostic pop")
|
#define END_ALLOW_CASE_RANGE _Pragma("GCC diagnostic pop")
|
||||||
#define ALLOW_UNUSED_RESULT _Pragma("GCC diagnostic ignored \"-Wunused-result\"")
|
#define ALLOW_UNUSED_RESULT _Pragma("GCC diagnostic ignored \"-Wunused-result\"")
|
||||||
#define END_ALLOW_UNUSED_RESULT _Pragma("GCC diagnostic pop")
|
#define END_ALLOW_UNUSED_RESULT _Pragma("GCC diagnostic pop")
|
||||||
|
#endif
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
PyObject_HEAD
|
PyObject_HEAD
|
||||||
|
|||||||
@ -195,7 +195,6 @@ static PyObject*
|
|||||||
as_ansi(Line* self) {
|
as_ansi(Line* self) {
|
||||||
#define as_ansi_doc "Return the line's contents with ANSI (SGR) escape codes for formatting"
|
#define as_ansi_doc "Return the line's contents with ANSI (SGR) escape codes for formatting"
|
||||||
static Py_UCS4 t[5120] = {0};
|
static Py_UCS4 t[5120] = {0};
|
||||||
if (t == NULL) return PyErr_NoMemory();
|
|
||||||
index_type num = line_as_ansi(self, t, 5120);
|
index_type num = line_as_ansi(self, t, 5120);
|
||||||
PyObject *ans = PyUnicode_FromKindAndData(PyUnicode_4BYTE_KIND, t, num);
|
PyObject *ans = PyUnicode_FromKindAndData(PyUnicode_4BYTE_KIND, t, num);
|
||||||
return ans;
|
return ans;
|
||||||
|
|||||||
@ -633,11 +633,8 @@ static inline void
|
|||||||
_parse_bytes(Screen *screen, uint8_t *buf, Py_ssize_t len, PyObject DUMP_UNUSED *dump_callback) {
|
_parse_bytes(Screen *screen, uint8_t *buf, Py_ssize_t len, PyObject DUMP_UNUSED *dump_callback) {
|
||||||
uint32_t prev = screen->utf8_state, codepoint = 0;
|
uint32_t prev = screen->utf8_state, codepoint = 0;
|
||||||
for (unsigned int i = 0; i < len; i++) {
|
for (unsigned int i = 0; i < len; i++) {
|
||||||
switch(screen->use_latin1) {
|
if (screen->use_latin1) dispatch_unicode_char(screen, latin1_charset[buf[i]], dump_callback);
|
||||||
case true:
|
else {
|
||||||
dispatch_unicode_char(screen, latin1_charset[buf[i]], dump_callback);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
switch (decode_utf8(&screen->utf8_state, &codepoint, buf[i])) {
|
switch (decode_utf8(&screen->utf8_state, &codepoint, buf[i])) {
|
||||||
case UTF8_ACCEPT:
|
case UTF8_ACCEPT:
|
||||||
dispatch_unicode_char(screen, codepoint, dump_callback);
|
dispatch_unicode_char(screen, codepoint, dump_callback);
|
||||||
@ -647,7 +644,6 @@ _parse_bytes(Screen *screen, uint8_t *buf, Py_ssize_t len, PyObject DUMP_UNUSED
|
|||||||
if (prev != UTF8_ACCEPT) i--;
|
if (prev != UTF8_ACCEPT) i--;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
FLUSH_DRAW;
|
FLUSH_DRAW;
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user