diff options
author | Lars Schneider <larsxschneider@gmail.com> | 2018-04-15 20:16:05 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2018-04-16 04:40:56 +0200 |
commit | 10ecb82e4f1f507d5f122e00fd4829b30953f853 (patch) | |
tree | 58e2245d175a29290fc4405988ab650b5b669207 /utf8.h | |
parent | utf8: teach same_encoding() alternative UTF encoding names (diff) | |
download | git-10ecb82e4f1f507d5f122e00fd4829b30953f853.tar.xz git-10ecb82e4f1f507d5f122e00fd4829b30953f853.zip |
utf8: add function to detect prohibited UTF-16/32 BOM
Whenever a data stream is declared to be UTF-16BE, UTF-16LE, UTF-32BE
or UTF-32LE a BOM must not be used [1]. The function returns true if
this is the case.
This function is used in a subsequent commit.
[1] http://unicode.org/faq/utf_bom.html#bom10
Signed-off-by: Lars Schneider <larsxschneider@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to '')
-rw-r--r-- | utf8.h | 9 |
1 files changed, 9 insertions, 0 deletions
@@ -70,4 +70,13 @@ typedef enum { void strbuf_utf8_align(struct strbuf *buf, align_type position, unsigned int width, const char *s); +/* + * If a data stream is declared as UTF-16BE or UTF-16LE, then a UTF-16 + * BOM must not be used [1]. The same applies for the UTF-32 equivalents. + * The function returns true if this rule is violated. + * + * [1] http://unicode.org/faq/utf_bom.html#bom10 + */ +int has_prohibited_utf_bom(const char *enc, const char *data, size_t len); + #endif |