mirror of
https://github.com/jart/cosmopolitan.git
synced 2025-01-31 11:37:35 +00:00
e16a7d8f3b
`et` means `expandtab`. ```sh rg 'vi: .* :vi' -l -0 | \ xargs -0 sed -i '' 's/vi: \(.*\) et\(.*\) :vi/vi: \1 xoet\2:vi/' rg 'vi: .* :vi' -l -0 | \ xargs -0 sed -i '' 's/vi: \(.*\)noet\(.*\):vi/vi: \1et\2 :vi/' rg 'vi: .* :vi' -l -0 | \ xargs -0 sed -i '' 's/vi: \(.*\)xoet\(.*\):vi/vi: \1noet\2:vi/' ```
42 lines
2.1 KiB
C
42 lines
2.1 KiB
C
/*-*- mode:c;indent-tabs-mode:nil;c-basic-offset:4;tab-width:8;coding:utf-8 -*-│
|
|
│ vi: set et ft=c ts=4 sts=4 sw=4 fenc=utf-8 :vi │
|
|
╞══════════════════════════════════════════════════════════════════════════════╡
|
|
│ Python 3 │
|
|
│ https://docs.python.org/3/license.html │
|
|
╚─────────────────────────────────────────────────────────────────────────────*/
|
|
#include "third_party/python/Modules/unicodedata.h"
|
|
|
|
/**
|
|
* Returns 1 if the input is certainly normalized, 0 if it might not be.
|
|
*/
|
|
int
|
|
_PyUnicode_IsNormalized(PyObject *self, PyObject *input, int nfc, int k)
|
|
{
|
|
int kind;
|
|
void *data;
|
|
Py_ssize_t i, len;
|
|
unsigned char prev_combining = 0, quickcheck_mask;
|
|
/* An older version of the database is requested, quickchecks must be
|
|
disabled. */
|
|
if (self && UCD_Check(self))
|
|
return 0;
|
|
/* The two quickcheck bits at this shift mean 0=Yes, 1=Maybe, 2=No,
|
|
as described in http://unicode.org/reports/tr15/#Annex8. */
|
|
quickcheck_mask = 3 << ((nfc ? 4 : 0) + (k ? 2 : 0));
|
|
i = 0;
|
|
kind = PyUnicode_KIND(input);
|
|
data = PyUnicode_DATA(input);
|
|
len = PyUnicode_GET_LENGTH(input);
|
|
while (i < len) {
|
|
Py_UCS4 ch = PyUnicode_READ(kind, data, i++);
|
|
const _PyUnicode_Record *record = _PyUnicode_GetRecord(ch);
|
|
unsigned char combining = record->combining;
|
|
unsigned char quickcheck = record->normalization_quick_check;
|
|
if (quickcheck & quickcheck_mask)
|
|
return 0; /* this string might need normalization */
|
|
if (combining && prev_combining > combining)
|
|
return 0; /* non-canonical sort order, not normalized */
|
|
prev_combining = combining;
|
|
}
|
|
return 1; /* certainly normalized */
|
|
}
|