From 46b642583859c6e1d2a1891179e2a5ca15f7bbbb Mon Sep 17 00:00:00 2001 From: Project Nayuki Date: Wed, 3 Oct 2018 21:10:13 +0000 Subject: [PATCH] Simplified some logic in Java QrSegmentAdvanced using Java SE 8 streams and lambdas. --- java/io/nayuki/qrcodegen/QrSegmentAdvanced.java | 13 +++++-------- 1 file changed, 5 insertions(+), 8 deletions(-) diff --git a/java/io/nayuki/qrcodegen/QrSegmentAdvanced.java b/java/io/nayuki/qrcodegen/QrSegmentAdvanced.java index e1e64bc..c3a9d71 100644 --- a/java/io/nayuki/qrcodegen/QrSegmentAdvanced.java +++ b/java/io/nayuki/qrcodegen/QrSegmentAdvanced.java @@ -234,12 +234,12 @@ public final class QrSegmentAdvanced { public static QrSegment makeKanji(String text) { Objects.requireNonNull(text); BitBuffer bb = new BitBuffer(); - for (int i = 0; i < text.length(); i++) { - int val = UNICODE_TO_QR_KANJI[text.charAt(i)]; + text.chars().forEachOrdered(c -> { + int val = UNICODE_TO_QR_KANJI[c]; if (val == -1) throw new IllegalArgumentException("String contains non-kanji-mode characters"); bb.appendBits(val, 13); - } + }); return new QrSegment(Mode.KANJI, text.length(), bb); } @@ -256,11 +256,8 @@ public final class QrSegmentAdvanced { */ public static boolean isEncodableAsKanji(String text) { Objects.requireNonNull(text); - for (int i = 0; i < text.length(); i++) { - if (!isKanji(text.charAt(i))) - return false; - } - return true; + return text.chars().allMatch( + c -> isKanji((char)c)); }