aesthetic improvements to NullPrecedence enum

This commit is contained in:
Gavin King 2023-06-28 16:33:55 +02:00
parent 49f890d781
commit c29db563b5
1 changed files with 45 additions and 47 deletions

View File

@ -6,10 +6,12 @@
*/ */
package org.hibernate.query; package org.hibernate.query;
import org.hibernate.query.sqm.NullOrdering; import org.hibernate.AssertionFailure;
import org.hibernate.dialect.NullOrdering;
/** /**
* Defines precedence of null values within {@code ORDER BY} clause. * Enumerates the possibilities for the precedence of null values within
* query result sets sorted by an {@code ORDER BY} clause.
* *
* @author Lukasz Antoniak * @author Lukasz Antoniak
*/ */
@ -17,53 +19,53 @@ public enum NullPrecedence {
/** /**
* Null precedence not specified. Relies on the RDBMS implementation. * Null precedence not specified. Relies on the RDBMS implementation.
*/ */
NONE { NONE,
@Override
public boolean isDefaultOrdering(SortOrder sortOrder, NullOrdering nullOrdering) {
return true;
}
},
/** /**
* Null values appear at the beginning of the sorted collection. * Null values appear at the beginning of the sorted collection.
*/ */
FIRST { FIRST,
@Override
public boolean isDefaultOrdering(SortOrder sortOrder, NullOrdering nullOrdering) {
switch ( nullOrdering ) {
case FIRST:
return true;
case SMALLEST:
return sortOrder == SortOrder.ASCENDING;
case GREATEST:
return sortOrder == SortOrder.DESCENDING;
}
return false;
}
},
/** /**
* Null values appear at the end of the sorted collection. * Null values appear at the end of the sorted collection.
*/ */
LAST { LAST;
@Override
public boolean isDefaultOrdering(SortOrder sortOrder, NullOrdering nullOrdering) {
switch ( nullOrdering ) {
case LAST:
return true;
case SMALLEST:
return sortOrder == SortOrder.DESCENDING;
case GREATEST:
return sortOrder == SortOrder.ASCENDING;
}
return false;
}
};
/** /**
* Is this null precedence the default for the given sort order and null ordering. * Is this null precedence the default for the given sort order and null ordering.
*/ */
public abstract boolean isDefaultOrdering(SortOrder sortOrder, NullOrdering nullOrdering); public boolean isDefaultOrdering(SortOrder sortOrder, NullOrdering nullOrdering) {
switch (this) {
case NONE:
return true;
case FIRST:
switch ( nullOrdering ) {
case FIRST:
return true;
case LAST:
return false;
case SMALLEST:
return sortOrder == SortOrder.ASCENDING;
case GREATEST:
return sortOrder == SortOrder.DESCENDING;
default:
throw new AssertionFailure("Unrecognized NullOrdering");
}
case LAST:
switch ( nullOrdering ) {
case LAST:
return true;
case FIRST:
return false;
case SMALLEST:
return sortOrder == SortOrder.DESCENDING;
case GREATEST:
return sortOrder == SortOrder.ASCENDING;
default:
throw new AssertionFailure("Unrecognized NullOrdering");
}
default:
throw new AssertionFailure("Unrecognized NullPrecedence");
}
}
/** /**
* Interprets a string representation of a NullPrecedence, returning {@code null} by default. For * Interprets a string representation of a NullPrecedence, returning {@code null} by default. For
@ -74,14 +76,10 @@ public enum NullPrecedence {
* @return The recognized NullPrecedence, or {@code null} * @return The recognized NullPrecedence, or {@code null}
*/ */
public static NullPrecedence parse(String name) { public static NullPrecedence parse(String name) {
if ( "none".equalsIgnoreCase( name ) ) { for ( NullPrecedence value : values() ) {
return NullPrecedence.NONE; if ( value.name().equalsIgnoreCase( name ) ) {
return value;
} }
else if ( "first".equalsIgnoreCase( name ) ) {
return NullPrecedence.FIRST;
}
else if ( "last".equalsIgnoreCase( name ) ) {
return NullPrecedence.LAST;
} }
return null; return null;
} }