From: Roland Häder Date: Thu, 15 Mar 2018 23:34:52 +0000 (+0100) Subject: Continued: X-Git-Url: https://git.mxchange.org/?a=commitdiff_plain;h=942c13f4b1ceb67fc37c1df42c8c7065686a9f94;p=jcoreee.git Continued: - added utility class Comparables which is intended for compareTo() tests on objects/entities - changed copyright to Free Software Foundation Signed-off-by: Roland Häder --- diff --git a/src/org/mxchange/jcoreee/utils/Comparables.java b/src/org/mxchange/jcoreee/utils/Comparables.java new file mode 100644 index 0000000..b5287f0 --- /dev/null +++ b/src/org/mxchange/jcoreee/utils/Comparables.java @@ -0,0 +1,69 @@ +/* + * Copyright (C) 2018 Free Software Foundation + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . + */ +package org.mxchange.jcoreee.utils; + +import java.io.Serializable; + +/** + * An utilities class for comparison of objects/entities + *

+ * @author Roland Häder + */ +public class Comparables implements Serializable { + + /** + * Serial number + */ + private static final long serialVersionUID = 19_286_457_671_390L; + + /** + * Checks all comparison values if they are not zero and returns proper + * value. These comparators should come from an implementation of + * Comparable.compareTo(). + *

+ * @param comparators An array of at least one comparator + *

+ * @return Comparison value + */ + public static int checkAll (final int[] comparators) { + // Is array empty? + if (comparators.length == 0) { + // Should not happen + throw new IllegalArgumentException("comparators is empty."); //NOI18N + } + + // Loop through all + for (int i = 0; i < comparators.length; i++) { + // Is it smaller or bigger? + if (comparators[i] < 0) { + return -1; + } else if (comparators[i] > 0) { + return 1; + } + } + + // Assume euqality + return 0; + } + + /** + * Utility classes should not have instances + */ + private Comparables () { + } + +} diff --git a/src/org/mxchange/jcoreee/utils/StringUtils.java b/src/org/mxchange/jcoreee/utils/StringUtils.java index 7a3d6c2..e69535a 100644 --- a/src/org/mxchange/jcoreee/utils/StringUtils.java +++ b/src/org/mxchange/jcoreee/utils/StringUtils.java @@ -1,5 +1,5 @@ /* - * Copyright (C) 2018 Roland Häder + * Copyright (C) 2018 Free Software Foundation * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -42,7 +42,7 @@ public class StringUtils implements Serializable { * 2 means str0 bigger str2 */ @SuppressWarnings ("null") - public static int comareTo (final String str0, final String str1) { + public static int compareTo (final String str0, final String str1) { // Check both strings for null and empty boolean isStr0Empty = (str0 == null || str0.isEmpty()); boolean isStr1Empty = (str1 == null || str1.isEmpty()); @@ -72,7 +72,7 @@ public class StringUtils implements Serializable { * 2 means str0 bigger str2 */ @SuppressWarnings ("null") - public static int comareToIgnoreCase (final String str0, final String str1) { + public static int compareToIgnoreCase (final String str0, final String str1) { // Check both strings for null and empty boolean isStr0Empty = (str0 == null || str0.isEmpty()); boolean isStr1Empty = (str1 == null || str1.isEmpty());