Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/siddhesh/find-unicode-control
https://github.com/siddhesh/find-unicode-control
Last synced: 2 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/siddhesh/find-unicode-control
- Owner: siddhesh
- License: bsd-3-clause
- Created: 2021-11-02T09:21:34.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2023-05-23T12:37:39.000Z (over 1 year ago)
- Last Synced: 2024-11-01T05:42:37.351Z (3 months ago)
- Language: Python
- Size: 29.3 KB
- Stars: 24
- Watchers: 2
- Forks: 8
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# find-unicode-control
These scripts look for non-printable unicode characters in all text files in a
source tree. `find_unicode_control.py` should work with python2 as well as
python3. It uses `python-magic` if available to determine file type, or simply
spawns the `file --mime-type` command. They should be functionally the same
and `find_unicode_control.py` could eventually get disposed.```
usage: find_unicode_control.py [-h] [-p {all,bidi}] [-v] [-c CONFIG] path [path ...]Look for Unicode control characters
positional arguments:
path Sources to analyzeoptional arguments:
-h, --help show this help message and exit
-p {all,bidi}, --nonprint {all,bidi}
Look for either all non-printable unicode characters or bidirectional control characters.
-v, --verbose Verbose mode.
-d, --detailed Print line numbers where characters occur.
-t, --notests Exclude tests (basically test.* as a component of path).
-c CONFIG, --config CONFIG
Configuration file to read settings from.
```If unicode BIDI control characters or non-printable characters are found in a
file, it will print output as follows:```
$ python3 find_unicode_control.py -p bidi *.c
commenting-out.c: bidirectional control characters: {'\u202e', '\u2066', '\u2069'}
early-return.c: bidirectional control characters: {'\u2067'}
stretched-string.c: bidirectional control characters: {'\u202e', '\u2066', '\u2069'}
```Using the `-d` flag, the output is more detailed, showing line numbers in
files, but this mode is also slower:```
find_unicode_control.py -p bidi -d .
./commenting-out.c:4 bidirectional control characters: ['\u202e', '\u2066', '\u2069', '\u2066']
./commenting-out.c:6 bidirectional control characters: ['\u202e', '\u2066']
./early-return.c:4 bidirectional control characters: ['\u2067']
./stretched-string.c:6 bidirectional control characters: ['\u202e', '\u2066', '\u2069', '\u2066']
```The optimal workflow would be to do a quick scan through a source tree and if
any issues are found, do a detailed scan on only those files.## Configuration file
If files need to be excluded from the scan, make a configuration file and
define a `scan_exclude` variable to a list of regular expressions that match
the files or paths to exclude. Alternatively, add a `scan_exclude_mime` list
with the list of mime types to ignore; this can again be a regular expression.
Here is an example configuration that glibc uses:```
scan_exclude = [
# Iconv test data
r'/iconvdata/testdata/',
# Test case data
r'libio/tst-widetext.input$',
# Test script. This is to silence the warning:
# 'utf-8' codec can't decode byte 0xe9 in position 2118: invalid continuation byte
# since the script tests mixed encoding characters.
r'localedata/tst-langinfo.sh$']
```## Notes
This script was quickly hacked together to scan repositories with mostly LTR,
unicode content. If you have RTL content (either in comments, literals or even
identifiers in code), it will give false warnings that you need to weed out.
For now you need to exclude such RTL code using `scan_exclude` but a long term
wish list (if this remains relevant, hopefully more sophisticated RTL
diagnostics will make it obsolete!) is to handle RTL a bit more intelligently.