From 18ff8dc0e552806c883821d76167eaf55c42ad30 Mon Sep 17 00:00:00 2001 From: Project Nayuki Date: Wed, 3 Oct 2018 21:01:23 +0000 Subject: [PATCH] Refactored Java QrSegmentAdvanced to move a piece of logic to a new function. --- .../nayuki/qrcodegen/QrSegmentAdvanced.java | 21 ++++++++++--------- 1 file changed, 11 insertions(+), 10 deletions(-) diff --git a/java/io/nayuki/qrcodegen/QrSegmentAdvanced.java b/java/io/nayuki/qrcodegen/QrSegmentAdvanced.java index 6b52f67..e1e64bc 100644 --- a/java/io/nayuki/qrcodegen/QrSegmentAdvanced.java +++ b/java/io/nayuki/qrcodegen/QrSegmentAdvanced.java @@ -112,16 +112,7 @@ public final class QrSegmentAdvanced { int c = codePoints[i]; int[] curCosts = new int[numModes]; { // Always extend a bytes segment - int b; - if (c < 0x80) - b = 1; - else if (c < 0x800) - b = 2; - else if (c < 0x10000) - b = 3; - else - b = 4; - curCosts[0] = prevCosts[0] + b * 8 * 6; + curCosts[0] = prevCosts[0] + countUtf8Bytes(c) * 8 * 6; charModes[i][0] = modeTypes[0]; } // Extend a segment if possible @@ -216,6 +207,16 @@ public final class QrSegmentAdvanced { } + private static int countUtf8Bytes(int cp) { + if (cp < 0) throw new IllegalArgumentException("Invalid code point"); + else if (cp < 0x80) return 1; + else if (cp < 0x800) return 2; + else if (cp < 0x10000) return 3; + else if (cp < 0x110000) return 4; + else throw new IllegalArgumentException("Invalid code point"); + } + + /*---- Kanji mode segment encoder ----*/