Zbigniew Jędrzejewski-Szmek 794d16
From 5b5f505ab485dd60fb608ffb2eecd755537f039f Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek 794d16
From: =?UTF-8?q?Zbigniew=20J=C4=99drzejewski-Szmek?= <zbyszek@in.waw.pl>
Zbigniew Jędrzejewski-Szmek 794d16
Date: Sat, 5 Oct 2013 22:47:52 -0400
Zbigniew Jędrzejewski-Szmek 794d16
Subject: [PATCH] utf8: fix utf8_is_printable
Zbigniew Jędrzejewski-Szmek 794d16
Zbigniew Jędrzejewski-Szmek 794d16
---
Zbigniew Jędrzejewski-Szmek 794d16
 src/shared/utf8.c    | 5 +++--
Zbigniew Jędrzejewski-Szmek 794d16
 src/test/test-utf8.c | 1 +
Zbigniew Jędrzejewski-Szmek 794d16
 2 files changed, 4 insertions(+), 2 deletions(-)
Zbigniew Jędrzejewski-Szmek 794d16
Zbigniew Jędrzejewski-Szmek 794d16
diff --git a/src/shared/utf8.c b/src/shared/utf8.c
Zbigniew Jędrzejewski-Szmek 794d16
index a8e28ac..31120af 100644
Zbigniew Jędrzejewski-Szmek 794d16
--- a/src/shared/utf8.c
Zbigniew Jędrzejewski-Szmek 794d16
+++ b/src/shared/utf8.c
Zbigniew Jędrzejewski-Szmek 794d16
@@ -141,14 +141,15 @@ bool utf8_is_printable(const char* str, size_t length) {
Zbigniew Jędrzejewski-Szmek 794d16
 
Zbigniew Jędrzejewski-Szmek 794d16
         assert(str);
Zbigniew Jędrzejewski-Szmek 794d16
 
Zbigniew Jędrzejewski-Szmek 794d16
-        for (p = (const uint8_t*) str; length; p++) {
Zbigniew Jędrzejewski-Szmek 794d16
+        for (p = (const uint8_t*) str; length;) {
Zbigniew Jędrzejewski-Szmek 794d16
                 int encoded_len = utf8_encoded_valid_unichar((const char *)p);
Zbigniew Jędrzejewski-Szmek 794d16
-                int32_t val = utf8_encoded_to_unichar((const char*)p);
Zbigniew Jędrzejewski-Szmek 794d16
+                int val = utf8_encoded_to_unichar((const char*)p);
Zbigniew Jędrzejewski-Szmek 794d16
 
Zbigniew Jędrzejewski-Szmek 794d16
                 if (encoded_len < 0 || val < 0 || is_unicode_control(val))
Zbigniew Jędrzejewski-Szmek 794d16
                         return false;
Zbigniew Jędrzejewski-Szmek 794d16
 
Zbigniew Jędrzejewski-Szmek 794d16
                 length -= encoded_len;
Zbigniew Jędrzejewski-Szmek 794d16
+                p += encoded_len;
Zbigniew Jędrzejewski-Szmek 794d16
         }
Zbigniew Jędrzejewski-Szmek 794d16
 
Zbigniew Jędrzejewski-Szmek 794d16
         return true;
Zbigniew Jędrzejewski-Szmek 794d16
diff --git a/src/test/test-utf8.c b/src/test/test-utf8.c
Zbigniew Jędrzejewski-Szmek 794d16
index 7bd0db1..f0182ee 100644
Zbigniew Jędrzejewski-Szmek 794d16
--- a/src/test/test-utf8.c
Zbigniew Jędrzejewski-Szmek 794d16
+++ b/src/test/test-utf8.c
Zbigniew Jędrzejewski-Szmek 794d16
@@ -26,6 +26,7 @@ static void test_utf8_is_printable(void) {
Zbigniew Jędrzejewski-Szmek 794d16
         assert_se(utf8_is_printable("ascii is valid\tunicode", 22));
Zbigniew Jędrzejewski-Szmek 794d16
         assert_se(utf8_is_printable("\342\204\242", 3));
Zbigniew Jędrzejewski-Szmek 794d16
         assert_se(!utf8_is_printable("\341\204", 2));
Zbigniew Jędrzejewski-Szmek 794d16
+        assert_se(utf8_is_printable("ąę", 4));
Zbigniew Jędrzejewski-Szmek 794d16
 }
Zbigniew Jędrzejewski-Szmek 794d16
 
Zbigniew Jędrzejewski-Szmek 794d16
 static void test_utf8_is_valid(void) {