-
2.4.2
- Fixed compatibility issues with
StringUtilities.Method parameters changed from String to CharSequence broke backward compatibility. Linked jars are bound to method signature at compile time, not at runtime. Added both methods where needed. Removed methods with "Not" in the name. - Fixed compatibility issue with
FastByteArrayOutputStream.The.getBuffer()API was removed in favor of toByteArray(). Now both methods exist, leavinggetBuffer()for backward compatibility. - The Converter "Everything" test updated to track which pairs are tested (fowarded or reverse) and then outputs in order what tests combinations are left to write.
- Fixed compatibility issues with
-
2.4.1
Converterhas had significant expansion in the types that it can convert between, about 670 combinations. In addition, you can add your own conversions to it as well. Call theConverter.getSupportedConversions()to see all the combinations supported. Also, you can useConverterinstance-based now, allowing it to have different conversion tables if needed.DateUtilitieshas had performance improvements (> 35%), and adds a new.parseDate()API that allows it to return aZonedDateTime.See the updated Javadoc on the class for a complete description of all the formats it supports. Normally, you do not need to use this class directly, as you can useConverterto convert betweenDates,Calendars, and the new Temporal classes likeZonedDateTime,Duration,Instance,as well as Strings.FastByteArrayOutputStreamupdated to matchByteArrayOutputStreamAPI. This means that.getBuffer()is.toByteArray()and.clear()is now.reset().FastByteArrayInputStreamadded. MatchesByteArrayInputStreamAPI.- Bug fix:
SafeSimpleDateFormatto properly format dates having years with fewer than four digits. - Bug fix: SafeSimpleDateFormat .toString(), .hashCode(), and .equals() now delegate to the contain SimpleDataFormat instance. We recommend using the newer DateTimeFormatter, however, this class works well for Java 1.8+ if needed.
-
2.4.0
- Added ClassUtilities. This class has a method to get the distance between a source and destination class. It includes support for Classes, multiple inheritance of interfaces, primitives, and class-to-interface, interface-interface, and class to class.
- Added LRUCache. This class provides a simple cache API that will evict the least recently used items, once a threshold is met.
-
2.3.0
- Added
FastReaderandFastWriter.FastReadercan be used instead of the JDKPushbackReader(BufferedReader)).It is much faster with no synchronization and combines both. It also tracks line[getLine()]and column[getCol()]position monitoring for0x0awhich it can be queried for. It also can be queried for the last snippet read:getLastSnippet().Great for showing parsing error messages that accurately point out where a syntax error occurred. Make sure you use a new instance per each thread.FastWritercan be used instead of the JDKBufferedWriteras it has no synchronization. Make sure you use a new Instance per each thread.
- Added
-
2.2.0
- Built with JDK 1.8 and runs with JDK 1.8 through JDK 21.
- The 2.2.x will continue to maintain JDK 1.8. The 3.0 branch [not yet created] will be JDK11+
- Added tests to verify that
GraphComparatorandDeepEqualsdo not count sorted order of Sets for equivalency. It does however, requireCollectionsthat are notSetsto be in order.
-
2.1.1
- ReflectionUtils skips static fields, speeding it up and remove runtime warning (field SerialVersionUID). Supports JDK's up through 21.
-
2.1.0
DeepEquals.deepEquals(a, b)compares Sets and Maps without regards to order per the equality spec.- Updated all dependent libraries to latest versions as of 16 Sept 2023.
-
2.0.0
- Upgraded from Java 8 to Java 11.
- Updated
ReflectionUtils.getClassNameFromByteCode()to handle up to Java 17classfile format.
-
1.68.0
- Fixed:
UniqueIdGeneratornow correctly gets last two digits of ID using 3 attempts - JAVA_UTIL_CLUSTERID (optional), CF_INSTANCE_INDEX, and finally using SecuritRandom for the last two digits. - Removed
log4jin favor ofslf4jandlogback.
- Fixed:
-
1.67.0
- Updated log4j dependencies to version
2.17.1.
- Updated log4j dependencies to version
-
1.66.0
- Updated log4j dependencies to version
2.17.0.
- Updated log4j dependencies to version
-
1.65.0
- Bug fix: Options (IGNORE_CUSTOM_EQUALS and ALLOW_STRINGS_TO_MATCH_NUMBERS) were not propagated inside containers\
- Bug fix: When progagating options the Set of visited ItemsToCompare (or a copy if it) should be passed on to prevent StackOverFlow from occurring.
-
1.64.0
- Performance Improvement:
DateUtilitiesnow using non-greedy matching for regex's within date sub-parts. - Performance Improvement:
CompactMapupdated to use non-copying iterator for all non-Sorted Maps. - Performance Improvement:
StringUtilities.hashCodeIgnoreCase()slightly faster - calls JDK method that makes one less call internally.
- Performance Improvement:
-
1.63.0
- Performance Improvement: Anytime
CompactMap/CompactSetis copied internally, the destination map is pre-sized to correct size, eliminating growing underlying Map more than once. ReflectionUtils.getConstructor()added. Fetches Constructor, caches reflection operation - 2nd+ calls pull from cache.
- Performance Improvement: Anytime
-
1.62.0
- Updated
DateUtilitiesto handle sub-seconds precision more robustly. - Updated
GraphComparatorto add missing srcValue when MAP_PUT replaces existing value. @marcobjorge
- Updated
-
1.61.0
Converternow supportsLocalDate,LocalDateTime,ZonedDateTimeto/fromCalendar,Date,java.sql.Date,Timestamp,Long,BigInteger,BigDecimal,AtomicLong,LocalDate,LocalDateTime, andZonedDateTime.
-
1.60.0 [Java 1.8+]
- Updated to require Java 1.8 or newer.
UniqueIdGeneratorwill recognize Cloud FoundryCF_INSTANCE_INDEX, in addition toJAVA_UTIL_CLUSTERIDas an environment variable or Java system property. This will be the last two digits of the generated unique id (making it cluster safe). Alternatively, the value can be the name of another environment variable (detected by not being parseable as an int), in which case the value of the specified environment variable will be parsed as server id within cluster (value parsed as int, mod 100).- Removed a bunch of Javadoc warnings from build.
-
1.53.0 [Java 1.7+]
- Updated to consume
log4j 2.13.3- more secure.
- Updated to consume
-
1.52.0
ReflectionUtilsnow caches the methods it finds byClassLoaderandClass. Earlier, found methods were cached perClass. This did not handle the case when multipleClassLoaderswere used to load the same class with the same method. UsingReflectionUtilsto locate thefoo()method will find it inClassLoaderX.ClassA.foo()(and cache it as such), and if asked to find it inClassLoaderY.ClassA.foo(),ReflectionUtilswill not find it in the cache withClassLoaderX.ClassA.foo(), but it will fetch it fromClassLoaderY.ClassA.foo()and then cache the method with thatClassLoader/Classpairing.DeepEquals.equals()was not comparingBigDecimalscorrectly. If they had different scales but represented the same value, it would returnfalse. Now they are properly compared usingbd1.compareTo(bd2) == 0.DeepEquals.equals(x, y, options)has a new option. If you addALLOW_STRINGS_TO_MATCH_NUMBERSto the options map, then if aStringis being compared to aNumber(or vice-versa), it will convert theStringto aBigDecimaland then attempt to see if the values still match. If so, then it will continue. If it could not convert theStringto aNumber, or the convertedStringas aNumberdid not match,falseis returned.convertToBigDecimal()now handles very largelongsandAtomicLongscorrectly (before it returnedfalseif thelongswere greater than adouble'smax integer representation.)CompactCIHashSetandCompactCILinkedHashSetnow return a newMapthat is sized tocompactSize() + 1when switching from internal storage toHashSet/LinkedHashSetfor storage. This is purely a performance enhancement.
-
1.51.0
- New Sets:
CompactCIHashSetadded. ThisCompactSetexpands to a case-insensitiveHashSetwhensize() > compactSize().CompactCILinkedSetadded. ThisCompactSetexpands to a case-insensitiveLinkedHashSetwhensize() > compactSize().CompactLinkedSetadded. ThisCompactSetexpands to aLinkedHashSetwhensize() > compactSize().CompactSetexists. ThisCompactSetexpands to aHashSetwhensize() > compactSize().
- New Maps
CompactCILinkedMapexists. ThisCompactMapexpands to a case-insensitiveLinkedHashMapwhensize() > compactSize()entries.CompactCIHashMapexists. ThisCompactMapexpands to a case-insensitiveHashMapwhensize() > compactSize()entries.CompactLinkedMapadded. ThisCompactMapexpands to aLinkedHashMapwhensize() > compactSize()entries.CompactMapexists. ThisCompactMapexpands to aHashMapwhensize() > compactSize()entries.
- New Sets:
-
1.50.0
CompactCIHashMapadded. This is aCompactMapthat is case insensitive. When more thancompactSize()entries are stored in it (default 80), it uses aCaseInsenstiveMapHashMapto hold its entries.CompactCILinkedMapadded. This is aCompactMapthat is case insensitive. When more thancompactSize()entries are stored in it (default 80), it uses aCaseInsenstiveMapLinkedHashMapto hold its entries.- Bug fix:
CompactMapentrySet()andkeySet()were not handling theretainAll(),containsAll(), andremoveAll()methods case-insensitively when case-insensitivity was activated. Convertermethods that convert to byte, short, int, and long now accepted String decimal numbers. The decimal portion is truncated.
-
1.49.0
- Added
CompactSet. Works similarly toCompactMapwith singleObject[]holding elements until it crossescompactSize()threshold.
ThisObject[]is adjusted dynamically as objects are added and removed.
- Added
-
1.48.0
- Added
charandCharactersupport toConvert.convert*() - Added full Javadoc to
Converter. - Performance improvement in
Iterator.remove()for all ofCompactMap'siterators:keySet().iterator(),entrySet().iterator, andvalues().iterator. - In order to get to 100% code coverage with Jacoco, added more tests for
Converter,CaseInsenstiveMap, andCompactMap.
- Added
-
1.47.0
Converter.convert2*()methods added: Ifnullpassed in, primitive 'logical zero' is returned. Example:Converter.convert(null, boolean.class)returnsfalse.Converter.convertTo*()methods: ifnullpassed in,nullis returned. Allows "tri-state" Boolean. Example:Converter.convert(null, Boolean.class)returnsnull.Converter.convert()converts usingconvertTo*()methods for primitive wrappers, andconvert2*()methods for primitive classes.Converter.setNullMode()removed.
-
1.46.0
CompactMapnow supports 4 stages of "growth", making it much smaller in memory than nearly anyMap. After0and1entries, and between2andcompactSize()entries, the entries in theMapare stored in anObject[](using same single member variable). The even elements the 'keys' and the odd elements are the associated 'values'. This array is dynamically resized to exactly match the number of stored entries. When more thancompactSize()entries are used, theMapthen uses theMapreturned from the overrideablegetNewMap()api to store the entries. In all cases, it maintains the underlying behavior of theMap.- Updated to consume
log4j 2.13.1
-
1.45.0
CompactMapnow supports case-insensitivity when using String keys. By default, it is case sensitive, but you can override theisCaseSensitive()method and returnfalse. This allows you to returnTreeMap(String.CASE_INSENSITIVE_ORDER)orCaseInsensitiveMapfrom thegetNewMap()method. With these overrides, CompactMap is now case insensitive, yet still 'compact.'Converter.setNullMode(Converter.NULL_PROPER | Converter.NULL_NULL)added to allow control over hownullvalues are converted. By default, passing anullvalue into primitiveconvert*()methods returns the primitive form of0orfalse.
If the static methodConverter.setNullMode(Converter.NULL_NULL)is called it will change the behavior of the primitiveconvert*()methods returnnull.
-
1.44.0
CompactMapintroduced.
CompactMapis aMapthat strives to reduce memory at all costs while retaining speed that is close toHashMap'sspeed. It does this by using only one (1) member variable (of typeObject) and changing it as theMapgrows. It goes from single value, to a singleMap Entry, to anObject[], and finally it uses aMap(user defined).CompactMapis especially small when0or1entries are stored in it. Whensize()is from2tocompactSize(), then entries are stored internally in singleObject[]. If thesize() > compactSize()then the entries are stored in a regularMap.
// If this key is used and only 1 element then only the value is stored protected K getSingleValueKey() { return "someKey"; } // Map you would like it to use when size() > compactSize(). HashMap is default protected abstract Map<K, V> getNewMap(); // If you want case insensitivity, return true and return new CaseInsensitiveMap or TreeMap(String.CASE_INSENSITIVE_PRDER) from getNewMap() protected boolean isCaseInsensitive() { return false; } // 1.45.0 // When size() > than this amount, the Map returned from getNewMap() is used to store elements. protected int compactSize() { return 100; } // 1.46.0This class only has one (1) member variable of type
Object. If there are no entries in it, then the value of that member variable takes on a pointer (points to sentinel value.)If the entry has a key that matches the value returned from
getSingleValueKey()then there is no key stored and the internal single member points to the value (still retried with 100% proper Map semantics).If the single entry's key does not match the value returned from
getSingleValueKey()then the internal field points to an internalClassCompactMapEntrywhich contains the key and the value (nothing else). Again, all APIs still operate the same.In this case, the single member variable points to a single Object[] that contains all the keys and values. The keys are in the even positions, the values are in the odd positions (1 up from the key). [0] = key, [1] = value, [2] = next key, [3] = next value, and so on. The Object[] is dynamically expanded until size() > compactSize(). In addition, it is dynamically shrunk until the size becomes 1, and then it switches to a single Map Entry or a single value.
In this case, the single member variable points to a
Mapinstance (supplied bygetNewMap()API that user supplied.) This allowsCompactMapto work with nearly allMaptypes. This Map supports null for the key and values, as long as the Map returned by getNewMap() supports null keys-values. -
1.43.0
CaseInsensitiveMap(Map orig, Map backing)added for allowing precise control of whatMapinstance is used to back theCaseInsensitiveMap. For example,
Map originalMap = someMap // has content already in it Map ciMap1 = new CaseInsensitiveMap(someMap, new TreeMap()) // Control Map type, but not initial capacity Map ciMap2 = new CaseInsensitiveMap(someMap, new HashMap(someMap.size())) // Control both Map type and initial capacity Map ciMap3 = new CaseInsensitiveMap(someMap, new Object2ObjectOpenHashMap(someMap.size())) // Control initial capacity and use specialized Map from fast-util.CaseInsensitiveMap.CaseInsensitiveString()constructor madepublic.
-
1.42.0
CaseInsensitiveMap.putObject(Object key, Object value)added for placing objects into typed Maps.
-
1.41.0
CaseInsensitiveMap.plus()and.minus()added to support+and-operators in languages like Groovy.CaseInsenstiveMap.CaseInsensitiveString(staticinner Class) is nowpublic.
-
1.40.0
- Added
ReflectionUtils.getNonOverloadedMethod()to support reflectively fetching methods with only Class and Method name available. This implies there is no method overloading.
- Added
-
1.39.0
- Added
ReflectionUtils.call(bean, methodName, args...)to allow one-step reflective calls. See Javadoc for any limitations. - Added
ReflectionUtils.call(bean, method, args...)to allow easy reflective calls. This version requires obtaining theMethodinstance first. This approach allows methods with the same name and number of arguments (overloaded) to be called. - All
ReflectionUtils.getMethod()APIs cache reflectively located methods to significantly improve performance when using reflection. - The
call()methods throw the target of the checkedInvocationTargetException. The checkedIllegalAccessExceptionis rethrown wrapped in a RuntimeException. This allows making reflective calls without having to handle these two checked exceptions directly at the call point. Instead, these exceptions are usually better handled at a high-level in the code.
- Added
-
1.38.0
- Enhancement:
UniqueIdGeneratornow generates the long ids in monotonically increasing order. @HonorKnight - Enhancement: New API [
getDate(uniqueId)] added toUniqueIdGeneratorthat when passed an ID that it generated, will return the time down to the millisecond when it was generated.
- Enhancement:
-
1.37.0
TestUtil.assertContainsIgnoreCase()andTestUtil.checkContainsIgnoreCase()APIs added. These are generally used in unit tests to check error messages for key words, in order (as opposed to doing.contains()on a string which allows the terms to appear in any order.)- Build targets classes in Java 1.7 format, for maximum usability. The version supported will slowly move up, but only based on necessity allowing for widest use of java-util in as many projects as possible.
-
1.36.0
Converter.convert()now bi-directionally supportsCalendar.class, e.g. Calendar to Date, SqlDate, Timestamp, String, long, BigDecimal, BigInteger, AtomicLong, and vice-versa.UniqueIdGenerator.getUniqueId19()is a new API for getting 19 digit unique IDs (a fulllongvalue) These are generated at a faster rate (10,000 per millisecond vs. 1,000 per millisecond) than the original (18-digit) API.- Hardcore test added for ensuring concurrency correctness with
UniqueIdGenerator. - Javadoc beefed up for
UniqueIdGenerator. - Updated public APIs to have proper support for generic arguments. For example Class<T>, Map<?, ?>, and so on. This eliminates type casting on the caller's side.
ExceptionUtilities.getDeepestException()added. This API locates the source (deepest) exception.
-
1.35.0
DeepEquals.deepEquals(), when comparingMaps, theMap.Entrytype holding theMap'sentries is no longer considered in equality testing. In the past, a custom Map.Entry instance holding the key and value could cause inquality, which should be ignored. @AndreyNudkoConverter.convert()now uses parameterized types so that the return type matches the passed inClassparameter. This eliminates the need to cast the return value ofConverter.convert().MapUtilities.getOrThrow()added which throws the passed inThrowablewhen the passed in key is not within theMap. @ptjuanramos
-
1.34.2
- Performance Improvement:
CaseInsensitiveMap, when created from anotherCaseInsensitiveMap, re-uses the internalCaseInsensitiveStringkeys, which are immutable. - Bug fix:
Converter.convertToDate(), Converter.convertToSqlDate(), and Converter.convertToTimestamp()all threw aNullPointerExceptionif the passed in content was an empty String (of 0 or more spaces). When passed in NULL to these APIs, you get back null. If you passed in empty strings or bad date formats, an IllegalArgumentException is thrown with a message clearly indicating what input failed and why.
- Performance Improvement:
-
1.34.0
- Enhancement:
DeepEquals.deepEquals(a, b options)added. The new options map supports a keyDeepEquals.IGNORE_CUSTOM_EQUALSwhich can be set to a Set of String class names. If any of the encountered classes in the comparison are listed in the Set, and the class has a custom.equals()method, it will not be called and instead adeepEquals()will be performed. If the value associated to theIGNORE_CUSTOM_EQUALSkey is an empty Set, then no custom.equals()methods will be called, except those on primitives, primitive wrappers,Date,Class, andString.
- Enhancement:
-
1.33.0
- Bug fix:
DeepEquals.deepEquals(a, b)could report equivalent unorderedCollections/Mapsas not equal if the items in theCollection/Maphad the same hash code.
- Bug fix:
-
1.32.0
Converterupdated to exposeconvertTo*()APIs that allow converting to a known type.
-
1.31.1
- Renamed
AdjustableFastGZIPOutputStreamtoAdjustableGZIPOutputStream.
- Renamed
-
1.31.0
- Add
AdjustableFastGZIPOutputStreamso that compression level can be adjusted.
- Add
-
1.30.0
ByteArrayOutputStreamsconverted toFastByteArrayOutputStreamsinternally.
-
1.29.0
- Removed test dependencies on Guava
- Rounded out APIs on
FastByteArrayOutputStream - Added APIs to
IOUtilities.
-
1.28.2
- Enhancement:
IOUtilities.compressBytes(FastByteArrayOutputStream, FastByteArrayOutputStream)added.
- Enhancement:
-
1.28.1
- Enhancement:
FastByteArrayOutputStream.getBuffer()API made public.
- Enhancement:
-
1.28.0
- Enhancement:
FastByteArrayOutputStreamadded. Similar to JDK class, but withoutsynchronizedand access to innerbyte[]allowed without duplicating thebyte[].
- Enhancement:
-
1.27.0
- Enhancement:
Converter.convert()now supportsenumtoString
- Enhancement:
-
1.26.1
- Bug fix: The internal class
CaseInsensitiveStringdid not implementComparableinterface correctly.
- Bug fix: The internal class
-
1.26.0
- Enhancement: added
getClassNameFromByteCode()API toReflectionUtils.
- Enhancement: added
-
1.25.1
- Enhancement: The Delta object returned by
GraphComparatorimplementsSerializablefor those usingObjectInputStream/ObjectOutputStream. Provided by @metlaivan (Ivan Metla)
- Enhancement: The Delta object returned by
-
1.25.0
- Performance improvement:
CaseInsensitiveMap/Setinternally addsStringstoMapwithout using.toLowerCase()which eliminates creating a temporary copy on the heap of theStringbeing added, just to get its lowerCaseValue. - Performance improvement:
CaseInsensitiveMap/Setuses less memory internally by caching the hash code as anint, instead of anInteger. StringUtilities.caseInsensitiveHashCode()API added. This allows computing a case-insensitive hashcode from aStringwithout any object creation (heap usage).
- Performance improvement:
-
1.24.0
Converter.convert()- performance improved using class instance comparison versus classStringname comparison.CaseInsensitiveMap/Set- performance improved.CaseInsensitiveString(internal) short-circuits on equality check if hashCode() [cheap runtime cost] is not the same. Also, all method returning true/false to detect ifSetorMapchanged rely on size() instead of contains.
-
1.23.0
Converter.convert()API update: When a mutable type (Date,AtomicInteger,AtomicLong,AtomicBoolean) is passed in, and the destination type is the same, rather than return the instance passed in, a copy of the instance is returned.
-
1.22.0
- Added
GraphComparatorwhich is used to compute the difference (delta) between two object graphs. The generatedListof Delta objects can be 'played' against the source to bring it up to match the target. Very useful in transaction processing systems.
- Added
-
1.21.0
- Added
Executorwhich is used to execute Operating System commands. For example,Executor exector = new Executor(); executor.exec("echo This is handy"); assertEquals("This is handy", executor.getOut().trim()); - bug fix:
CaseInsensitiveMap, when passed aLinkedHashMap, was inadvertently using a HashMap instead.
- Added
-
1.20.5
CaseInsensitiveMapintentionally does not retain 'not modifiability'.CaseInsensitiveSetintentionally does not retain 'not modifiability'.
-
1.20.4
- Failed release. Do not use.
-
1.20.3
TrackingMapchanged so thatget(anyKey)always marks it as keyRead. Same forcontainsKey(anyKey).CaseInsensitiveMaphas a constructor that takes aMap, which allows it to take on the nature of theMap, allowing for case-insensitiveConcurrentHashMap, sortedCaseInsensitiveMap, etc. The 'Unmodifiable'Mapnature is intentionally not taken on. The passed inMapis not mutated.CaseInsensitiveSethas a constructor that takes aCollection, nwhich allows it to take on the nature of theCollection, allowing for sortedCaseInsensitiveSets. The 'unmodifiable'Collectionnature is intentionally not taken on. The passed inSetis not mutated.
-
1.20.2
TrackingMapchanged so that an existing key associated to null counts as accessed. It is valid for manyMaptypes to allow null values to be associated to the key.TrackingMap.getWrappedMap()added so that you can fetch the wrappedMap.
-
1.20.1
TrackingMapchanged so that.put()does not mark the key as accessed.
-
1.20.0
TrackingMapadded. Create this map around any type of Map, and it will track which keys are accessed via .get(), .containsKey(), or .put() (when put overwrites a value already associated to the key). Provided by @seankellner.
-
1.19.3
- Bug fix:
CaseInsensitiveMap.entrySet()- callingentry.setValue(k, v)while iterating the entry set, was not updating the underlying value. This has been fixed and test case added.
- Bug fix:
-
1.19.2
- The order in which system properties are read versus environment variables via the
SystemUtilities.getExternalVariable()method has changed. System properties are checked first, then environment variables.
- The order in which system properties are read versus environment variables via the
-
1.19.1
- Fixed issue in
DeepEquals.deepEquals()where a Container type (MaporCollection) was being compared to a non-container - the result of this comparison was inconsistent. It is always false if a Container is compared to a non-container type (anywhere within the object graph), regardless of the comparison order A, B versus comparing B, A.
- Fixed issue in
-
1.19.0
StringUtilities.createUtf8String(byte[])API added which is used to easily create UTF-8 strings without exception handling code.StringUtilities.getUtf8Bytes(String s)API added which returns a byte[] of UTF-8 bytes from the passed in Java String without any exception handling code required.ByteUtilities.isGzipped(bytes[])API added which returns true if thebyte[]represents gzipped data.IOUtilities.compressBytes(byte[])API added which returns the gzipped version of the passed inbyte[]as abyte[]IOUtilities.uncompressBytes(byte[])API added which returns the original byte[] from the passed in gzippedbyte[].- JavaDoc issues correct to support Java 1.8 stricter JavaDoc compilation.
-
1.18.1
UrlUtilitiesnow allows for per-threaduserAgentandreferreras well as maintains backward compatibility for setting these values globally.StringUtilitiesgetBytes()andcreateString()now allow null as input, and return null for output for null input.- Javadoc updated to remove errors flagged by more stringent Javadoc 1.8 generator.
-
1.18.0
- Support added for
TimestampinConverter.convert() nullcan be passed intoConverter.convert()for primitive types, and it will return their logical 0 value (0.0f, 0.0d, etc.). For primitive wrappers, atomics, etc, null will be returned.- "" can be passed into
Converter.convert()and it will set primitives to 0, and the object types (primitive wrappers, dates, atomics) to null.Stringwill be set to "".
- Support added for
-
1.17.1
- Added full support for
AtomicBoolean,AtomicInteger, andAtomicLongtoConverter.convert(value, AtomicXXX). Any reasonable value can be converted to/from these, including Strings, Dates (AtomicLong), allNumbertypes. IOUtilities.flush()now supportsXMLStreamWriter
- Added full support for
-
1.17.0
UIUtilities.close()now supportsXMLStreamReaderandXMLStreamWriterin addition toCloseable.Converter.convert(value, type)- a value of null is supported for the numeric types, boolean, and the atomics - in which case it returns their "zero" value and false for boolean. For date and String return values, a null input will return null. Thetypeparameter must not be null.
-
1.16.1
- In
Converter.convert(value, type), the value is trimmed of leading / trailing white-space if it is a String and the type is aNumber.
- In
-
1.16.0
- Added
Converter.convert()API. Allows converting instances of one type to another. Handles all primitives, primitive wrappers,Date,java.sql.Date,String,BigDecimal,BigInteger,AtomicInteger,AtomicLong, andAtomicBoolean. Additionally, input (from) argument acceptsCalendar. - Added static
getDateFormat()toSafeSimpleDateFormatfor quick access to thread local formatter (per formatString).
- Added
-
1.15.0
- Switched to use Log4J2 () for logging.
-
1.14.1
- bug fix:
CaseInsensitiveMap.keySet()was only initializing the iterator once. IfkeySet()was called a 2nd time, it would no longer work.
- bug fix:
-
1.14.0
- bug fix:
CaseInsensitiveSet(), the return value foraddAll(),returnAll(), andretainAll()was wrong in some cases.
- bug fix:
-
1.13.3
EncryptionUtilities- Added byte[] APIs. Makes it easy to encrypt/decryptbyte[]data.pom.xmlhad extraneous characters inadvertently added to the file - these are removed.- 1.13.1 & 13.12 - issues with sonatype
-
1.13.0
DateUtilities- Day of week allowed (properly ignored).DateUtilities- First (st), second (nd), third (rd), and fourth (th) ... supported.DateUtilities- The default toString() standard date / time displayed by the JVM is now supported as a parseable format.DateUtilities- Extra whitespace can exist within the date string.DateUtilities- Full time zone support added.DateUtilities- The date (or date time) is expected to be in isolation. Whitespace on either end is fine, however, once the date time is parsed from the string, no other content can be left (prevents accidently parsing dates from dates embedded in text).UrlUtilities- Removed proxy from calls toURLUtilities. These are now done through the JVM.
-
1.12.0
UniqueIdGeneratoruses 99 as the cluster id when the JAVA_UTIL_CLUSTERID environment variable or System property is not available. This speeds up execution on developer's environments when they do not specifyJAVA_UTIL_CLUSTERID.- All the 1.11.x features rolled up.
-
1.11.3
UrlUtilities- separated out call that resolvesres://to a public API to allow for wider use.
-
1.11.2
- Updated so headers can be set individually by the strategy (
UrlInvocationHandler) InvocationHandlerset to always usesPOSTmethod to allow additionalHTTPheaders.
- Updated so headers can be set individually by the strategy (
-
1.11.1
- Better IPv6 support (
UniqueIdGenerator) - Fixed
UrlUtilities.getContentFromUrl()(byte[]) no longer setting upSSLFactorywhenHTTPprotocol used.
- Better IPv6 support (
-
1.11.0
UrlInvocationHandler,UrlInvocationStrategy- Updated to allow more generalized usage. Pass in your implementation ofUrlInvocationStrategywhich allows you to set the number of retry attempts, fill out the URL pattern, set up the POST data, and optionally set/get cookies.- Removed dependency on json-io. Only remaining dependency is Apache commons-logging.
-
1.10.0
- Issue #3 fixed:
DeepEquals.deepEquals()allows similarMap(orCollection) types to be compared without returning 'not equals' (false). Example,HashMapandLinkedHashMapare compared on contents only. However, compare aSortedSet(likeTreeMap) toHashMapwould fail unless the Map keys are in the same iterative order. - Tests added for
UrlUtilities - Tests added for
Traverser
- Issue #3 fixed:
-
1.9.2
- Added wildcard to regex pattern to
StringUtilities. This API turns a DOS-like wildcard pattern (where * matches anything and ? matches a single character) into a regex pattern useful inString.matches()API.
- Added wildcard to regex pattern to
-
1.9.1
- Floating-point allow difference by epsilon value (currently hard-coded on
DeepEquals. Will likely be optional parameter in future version).
- Floating-point allow difference by epsilon value (currently hard-coded on
-
1.9.0
MathUtilitiesadded. Currently, variable lengthminimum(arg0, arg1, ... argn)andmaximum()functions added. Available forlong,double,BigInteger, andBigDecimal. These cover the smaller types.CaseInsensitiveMapandCaseInsensitiveSetkeySet()andentrySet()are faster as they do not make a copy of the entries. Internally,CaseInsensitiveStringcaches it's hash, speeding up repeated access.StringUtilities levenshtein()anddamerauLevenshtein()added to compute edit length. See Wikipedia to understand of the difference between these two algorithms. Currently recommend usinglevenshtein()as it uses less memory.- The Set returned from the
CaseInsensitiveMap.entrySet()now contains mutable entry's (value-side). It had been using an immutable entry, which disallowed modification of the value-side during entry walk.
-
1.8.4
UrlUtilities, fixed issue where the default settings for the connection were changed, not the settings on the actual connection.
-
1.8.3
ReflectionUtilitieshas newgetClassAnnotation(classToCheck, annotation)API which will return the annotation if it exists within the classes super class hierarchy or interface hierarchy. Similarly, thegetMethodAnnotation()API does the same thing for method annotations (allow inheritance - class or interface).
-
1.8.2
CaseInsensitiveMapmethodskeySet()andentrySet()return Sets that are identical to how the JDK returns 'view' Sets on the underlying storage. This means that all operations, besidesadd()andaddAll(), are supported.CaseInsensitiveMap.keySet()returns aSetthat is case insensitive (not aCaseInsensitiveSet, just aSetthat ignores case). Iterating thisSetproperly returns each originally stored item.
-
1.8.1
- Fixed
CaseInsensitiveMap() removeAll()was not removing when accessed viakeySet()
- Fixed
-
1.8.0
- Added
DateUtilities. See description above.
- Added
-
1.7.4
- Added "res" protocol (resource) to
UrlUtilitiesto allow files from classpath to easily be loaded. Useful for testing.
- Added "res" protocol (resource) to
-
1.7.2
UrlUtilities.getContentFromUrl() / getContentFromUrlAsString()- removed hard-coded proxy server name
-
1.7.1
UrlUtilities.getContentFromUrl() / getContentFromUrlAsString()- allow content to be fetched asStringor binary (byte[]).
-
1.7.0
SystemUtilitiesadded. New API to fetch value from environment or System propertyUniqueIdGenerator- checks for environment variable (or System property) JAVA_UTIL_CLUSTERID (0-99). Will use this if set, otherwise last IP octet mod 100.
-
1.6.1
- Added:
UrlUtilities.getContentFromUrl()
- Added:
-
1.6.0
- Added
CaseInsensitiveSet.
- Added
-
1.5.0
- Fixed:
CaseInsensitiveMap's iterator.remove()method, it did not remove items. - Fixed:
CaseInsensitiveMap's equals()method, it required case to match on keys.
- Fixed:
-
1.4.0
- Initial version