All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.dbflute.cbean.coption.FromToOption Maven / Gradle / Ivy

/*
 * Copyright 2014-2015 the original author or authors.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
 * either express or implied. See the License for the specific language
 * governing permissions and limitations under the License.
 */
package org.dbflute.cbean.coption;

import java.time.LocalDate;
import java.time.LocalDateTime;
import java.util.Calendar;
import java.util.Date;
import java.util.List;
import java.util.TimeZone;

import org.dbflute.cbean.cipher.GearedCipherManager;
import org.dbflute.cbean.ckey.ConditionKey;
import org.dbflute.cbean.dream.SpecifiedColumn;
import org.dbflute.cbean.sqlclause.query.QueryClauseArranger;
import org.dbflute.dbway.ExtensionOperand;
import org.dbflute.dbway.OnQueryStringConnector;
import org.dbflute.helper.HandyDate;
import org.dbflute.system.DBFluteSystem;
import org.dbflute.util.DfCollectionUtil;
import org.dbflute.util.DfTypeUtil;

/**
 * The option of from-to scope for Date type.
 * 
 * e.g. from:{2007/04/10 08:24:53} to:{2007/04/16 14:36:29}
 * 
 * [Comparison Pattern]
 *   new FromToOption().compareAsYear();
 *     --> column >= '2007/01/01 00:00:00'
 *     and column < '2008/01/01 00:00:00'
 * 
 *   new FromToOption().compareAsMonth();
 *     --> column >= '2007/04/01 00:00:00'
 *     and column < '2007/05/01 00:00:00'
 * 
 *   new FromToOption().compareAsDate();
 *     --> column >= '2007/04/10 00:00:00'
 *     and column < '2007/04/17 00:00:00'
 * 
 *   new FromToOption().compareAsHour();
 *     --> column >= '2007/04/10 08:00:00'
 *     and column < '2007/04/16 15:00:00'
 * 
 *   new FromToOption().compareAsWeek().beginWeek_DayOfWeek1st_Sunday(); 
 *     --> column >= '2007/04/08 00:00:00'
 *     and column < '2008/04/22 00:00:00'
 * 
 *   new FromToOption().compareAsQuarterOfYear(); 
 *     --> column >= '2007/04/01 00:00:00'
 *     and column < '2007/07/01 00:00:00'
 * 
 * [Manual Adjustment]
 *   new FromToOption().greaterThan(); 
 *     --> column > '2007/04/10 08:24:53'
 *     and column <= '2007/04/16 14:36:29'
 * 
 *   new FromToOption().lessThan(); 
 *     --> column >= '2007/04/10 08:24:53'
 *     and column < '2007/04/16 14:36:29'
 * 
 *   new FromToOption().greaterThan().lessThan(); 
 *     --> column > '2007/04/10 08:24:53'
 *     and column < '2007/04/16 14:36:29'
 * 
 *   and so on...
 * 
 * [Default]
 *   new FromToOption(); 
 *     --> column >= '2007/04/10 08:24:53'
 *     and column <= '2007/04/16 14:36:29'
 * 
* @author jflute */ public class FromToOption implements ConditionOption { // =================================================================================== // Attribute // ========= protected boolean _greaterThan; protected boolean _lessThan; protected boolean _fromPatternYearJust; protected boolean _fromPatternMonthJust; protected boolean _fromPatternDayJust; protected boolean _fromPatternHourJust; protected boolean _fromPatternWeekJust; protected boolean _fromPatternQuarterOfYearJust; protected boolean _fromDateWithNoon; protected Integer _fromDateWithHour; protected boolean _toPatternNextYearJust; protected boolean _toPatternNextMonthJust; protected boolean _toPatternNextDayJust; protected boolean _toPatternNextHourJust; protected boolean _toPatternNextWeekJust; protected boolean _toPatternNextQuarterOfYearJust; protected boolean _toDateWithNoon; protected Integer _toDateWithHour; protected Integer _yearBeginMonth = 1; // as default protected Integer _monthBeginDay = 1; // as default protected Integer _dayBeginHour = 0; // as default protected Integer _weekBeginDay = Calendar.SUNDAY; // as default protected Integer _moveToScope; protected boolean _usePattern; protected boolean _orIsNull; /** Does it allow one-side only from-to? */ protected boolean _oneSideAllowed; /** The time-zone for filtering. (NullAllowed: if null, default zone) */ protected TimeZone _timeZone; // =================================================================================== // Comparison Pattern // ================== /** * Compare as year.
* The year part of the date is only used. * This method ignores operand adjustments and other patterns. *
     * e.g. from:{2007/04/10 08:24:53} to:{2008/08/16 14:36:29}
     * 
     *   new FromToOption().compareAsYear();
     *     --> column >= '2007/01/01 00:00:00'
     *     and column < '2009/01/01 00:00:00'
     * 
     *   new FromToOption().compareAsYear().beginYear_Month(4);
     *     --> column >= '2007/04/01 00:00:00'
     *     and column < '2009/04/01 00:00:00'
     * 
* @return this. (NotNull) */ public FromToOption compareAsYear() { fromPatternYearJust(); toPatternNextYearJust(); clearOperand(); lessThan(); _usePattern = true; return this; } /** * Compare as month.
* The year and month parts of the date are only used.
* This method ignores operand adjustments and other patterns. *
     * e.g. from:{2007/04/10 08:24:53} to:{2008/08/16 14:36:29}
     * 
     *   new FromToOption().compareAsMonth();
     *     --> column >= '2007/04/01 00:00:00'
     *     and column < '2008/09/01 00:00:00'
     * 
     *   new FromToOption().compareAsMonth().beginMonth_Day(3);
     *     --> column >= '2007/04/03 00:00:00'
     *     and column < '2008/09/03 00:00:00'
     * 
* @return this. (NotNull) */ public FromToOption compareAsMonth() { fromPatternMonthJust(); toPatternNextMonthJust(); clearOperand(); lessThan(); _usePattern = true; return this; } /** * Compare as date.
* The year, month, day parts of the date are only used.
* This method ignores operand adjustments and other patterns. *
     * e.g. from:{2007/04/10 08:24:53} to:{2007/04/16 14:36:29}
     * 
     *   new FromToOption().compareAsDate();
     *     --> column >= '2007/04/10 00:00:00'
     *     and column < '2007/04/17 00:00:00'
     * 
     *   new FromToOption().compareAsDate().beginDay_Hour(6);
     *     --> column >= '2007/04/10 06:00:00'
     *     and column < '2007/04/17 06:00:00'
     * 
* @return this. (NotNull) */ public FromToOption compareAsDate() { fromPatternDayJust(); toPatternNextDayJust(); clearOperand(); lessThan(); _usePattern = true; return this; } /** * Compare as hour.
* The year, month, day, hour parts of the date are only used.
* This method ignores operand adjustments and other patterns. *
     * e.g. from:{2007/04/10 08:24:53} to:{2007/04/16 14:36:29}
     * 
     *   new FromToOption().compareAsHour();
     *     --> column >= '2007/04/10 08:00:00'
     *     and column < '2007/04/16 15:00:00'
     * 
* @return this. (NotNull) */ public FromToOption compareAsHour() { fromPatternHourJust(); toPatternNextHourJust(); clearOperand(); lessThan(); _usePattern = true; return this; } /** * Compare as week.
* The year, month, day parts of the date are only used.
* This method ignores operand adjustments and other patterns.
* The default beginning day of week is Sunday, but you can change it by beginWeek_DayOfWeek...() methods. *
     * e.g. from:{2007/04/10 08:24:53} to:{2007/04/16 14:36:29}
     * 
     *   new FromToOption().compareAsWeek().beginWeek_DayOfWeek1st_Sunday();
     *     --> column >= '2007/04/08 00:00:00'
     *     and column < '2007/04/22 00:00:00'
     * 
* @return this. (NotNull) */ public FromToOption compareAsWeek() { fromPatternWeekJust(); toPatternNextWeekJust(); clearOperand(); lessThan(); _usePattern = true; return this; } /** * Compare as quarter of year.
* The year and month parts of the date are only used.
* This method ignores operand adjustments and other patterns.
* The default beginning of quarter of year is 1st month, but you can change it by beginYear_Month...() methods. *
     * e.g. from:{2007/04/10 08:24:53} to:{2008/08/16 14:36:29}
     * 
     *   new FromToOption().compareAsQuarterOfYear();
     *     --> column >= '2007/04/01 00:00:00'
     *     and column < '2008/10/01 00:00:00'
     * 
* @return this. (NotNull) */ public FromToOption compareAsQuarterOfYear() { fromPatternQuarterOfYearJust(); toPatternNextQuarterOfYearJust(); clearOperand(); lessThan(); _usePattern = true; return this; } public boolean isUsePattern() { // basically for framework return _usePattern; } // ----------------------------------------------------- // Begin Year // ---------- /** * Begin year from the specified month.
* The date of argument is used as only the month part. *
     * e.g. beginYear_Month(toLocalDate("2001/04/01"))
     *  year is from 4th month to 3rd month of next year
     *  (the 2011 year means 2011/04/01 to 2012/03/31)
     * 
     * e.g. option.compareAsYear().beginYear_Month(toLocalDate("2001/04/01"))
     *  if from-date is 2011/01/01 and to-date is 2012/01/01 (means 2011, 2012 year are target),
     *  the condition is: greater-equal 2011/04/01 and less-than 2013/04/04
     * 
* @param yearBeginMonth The local date that has the month of year-begin. (NotNull) * @return this. (NotNull) */ public FromToOption beginYear_Month(LocalDate yearBeginMonth) { // #dateParade return doBeginYear_Month(toDate(yearBeginMonth)); } /** * Begin year from the specified month.
* The date of argument is used as only the month part. *
     * e.g. beginYear_Month(toLocalDateTime("2001/04/01"))
     *  year is from 4th month to 3rd month of next year
     *  (the 2011 year means 2011/04/01 to 2012/03/31)
     * 
     * e.g. option.compareAsYear().beginYear_Month(toLocalDateTime("2001/04/01"))
     *  if from-date is 2011/01/01 and to-date is 2012/01/01 (means 2011, 2012 year are target),
     *  the condition is: greater-equal 2011/04/01 and less-than 2013/04/04
     * 
* @param yearBeginMonth The local date-time that has the month of year-begin. (NotNull) * @return this. (NotNull) */ public FromToOption beginYear_Month(LocalDateTime yearBeginMonth) { return doBeginYear_Month(toDate(yearBeginMonth)); } /** * Begin year from the specified month.
* The date of argument is used as only the month part. *
     * e.g. beginYear_Month(toDate("2001/04/01"))
     *  year is from 4th month to 3rd month of next year
     *  (the 2011 year means 2011/04/01 to 2012/03/31)
     * 
     * e.g. option.compareAsYear().beginYear_Month(toDate("2001/04/01"))
     *  if from-date is 2011/01/01 and to-date is 2012/01/01 (means 2011, 2012 year are target),
     *  the condition is: greater-equal 2011/04/01 and less-than 2013/04/04
     * 
* @param yearBeginMonth The date that has the month of year-begin. (NotNull) * @return this. (NotNull) */ public FromToOption beginYear_Month(Date yearBeginMonth) { return doBeginYear_Month(yearBeginMonth); } protected FromToOption doBeginYear_Month(Date yearBeginMonth) { assertPatternOptionValid("beginYear_Month"); assertArgumentNotNull("yearBeginMonth", yearBeginMonth); _yearBeginMonth = toHandyDate(yearBeginMonth).getMonthAsOneOrigin(); return this; } /** * Begin year from the specified month. *
     * e.g. beginYear_Month(4)
     *  year is from 4th month to 3rd month of next year
     *  (the 2011 year means 2011/04/01 to 2012/03/31)
     * 
     * e.g. option.compareAsYear().beginYear_Month(4)
     *  if from-date is 2011/01/01 and to-date is 2012/01/01 (means 2011, 2012 year are target),
     *  the condition is: greater-equal 2011/04/01 and less-than 2013/04/04
     * 
* @param yearBeginMonth The month for year-begin. (NotMinus, 1-12) * @return this. (NotNull) */ public FromToOption beginYear_Month(int yearBeginMonth) { assertPatternOptionValid("beginYear_Month"); assertNotMinusNotOver("yearBeginMonth", yearBeginMonth, 12); _yearBeginMonth = yearBeginMonth; return this; } /** * Begin year from January (1st month). * @return this. (NotNull) */ public FromToOption beginYear_Month01_January() { assertPatternOptionValid("beginYear_Month01_January"); _yearBeginMonth = 1; return this; } /** * Begin year from February (2nd month). * @return this. (NotNull) */ public FromToOption beginYear_Month02_February() { assertPatternOptionValid("beginYear_Month02_February"); _yearBeginMonth = 2; return this; } /** * Begin year from March (3rd month). * @return this. (NotNull) */ public FromToOption beginYear_Month03_March() { assertPatternOptionValid("beginYear_Month03_March"); _yearBeginMonth = 3; return this; } /** * Begin year from April (4th month). * @return this. (NotNull) */ public FromToOption beginYear_Month04_April() { assertPatternOptionValid("beginYear_Month04_April"); _yearBeginMonth = 4; return this; } /** * Begin year from May (5th month). * @return this. (NotNull) */ public FromToOption beginYear_Month05_May() { assertPatternOptionValid("beginYear_Month05_May"); _yearBeginMonth = 5; return this; } /** * Begin year from June (6th month). * @return this. (NotNull) */ public FromToOption beginYear_Month06_June() { assertPatternOptionValid("beginYear_Month06_June"); _yearBeginMonth = 6; return this; } /** * Begin year from July (7th month). * @return this. (NotNull) */ public FromToOption beginYear_Month07_July() { assertPatternOptionValid("beginYear_Month07_July"); _yearBeginMonth = 7; return this; } /** * Begin year from August (8th month). * @return this. (NotNull) */ public FromToOption beginYear_Month08_August() { assertPatternOptionValid("beginYear_Month08_August"); _yearBeginMonth = 8; return this; } /** * Begin year from September (9th month). * @return this. (NotNull) */ public FromToOption beginYear_Month09_September() { assertPatternOptionValid("beginYear_Month09_September"); _yearBeginMonth = 9; return this; } /** * Begin year from October (10th month). * @return this. (NotNull) */ public FromToOption beginYear_Month10_October() { assertPatternOptionValid("beginYear_Month10_October"); _yearBeginMonth = 10; return this; } /** * Begin year from November (11th month). * @return this. (NotNull) */ public FromToOption beginYear_Month11_November() { assertPatternOptionValid("beginYear_Month11_November"); _yearBeginMonth = 11; return this; } /** * Begin year from December (12th month). * @return this. (NotNull) */ public FromToOption beginYear_Month12_December() { assertPatternOptionValid("beginYear_Month12_December"); _yearBeginMonth = 12; return this; } /** * Begin year from the specified month of previous year. *
     * e.g. beginYear_PreviousMonth(11)
     *  year is from 11th month of previous year to 10th month of this year
     *  (the 2011 year means 2010/11/01 to 2011/10/31)
     * 
     * e.g. option.compareAsYear().beginYear_PreviousMonth(11)
     *  if from-date is 2011/01/01 and to-date is 2012/01/01 (means 2011, 2012 year are target),
     *  the condition is: greater-equal 2010/11/01 and less-than 2012/11/01
     * 
* @param yearBeginMonth The month of previous year for year-begin. (NotMinus, 1-12) * @return this. (NotNull) */ public FromToOption beginYear_PreviousMonth(int yearBeginMonth) { assertPatternOptionValid("beginYear_PreviousMonth"); assertNotMinusNotOver("yearBeginMonth", yearBeginMonth, 12); _yearBeginMonth = -yearBeginMonth; // to be minus return this; } // ----------------------------------------------------- // Begin Month // ----------- /** * Begin month from the specified day.
* The date of argument is used as only the day part. *
     * e.g. beginMonth_Day(toLocalDate("2001/01/03"))
     *  month is from 3 day to 2 day of next month
     *  (the 2011/11 means 2011/11/03 to 2011/12/02)
     * 
     * e.g. option.compareAsMonth().beginMonth_Day(toLocalDate("2001/01/03"))
     *  if from-date is 2011/11/01 and to-date is 2011/12/01 (means 11th, 12th months are target),
     *  the condition is: greater-equal 2011/11/03 and less-than 2012/01/03
     * 
* @param monthBeginDay The local date that has the day of month-begin. (NotNull) * @return this. (NotNull) */ public FromToOption beginMonth_Day(LocalDate monthBeginDay) { return doBeginMonth_Day(toDate(monthBeginDay)); } /** * Begin month from the specified day.
* The date of argument is used as only the day part. *
     * e.g. beginMonth_Day(toLocalDateTime("2001/01/03"))
     *  month is from 3 day to 2 day of next month
     *  (the 2011/11 means 2011/11/03 to 2011/12/02)
     * 
     * e.g. option.compareAsMonth().beginMonth_Day(toLocalDateTime("2001/01/03"))
     *  if from-date is 2011/11/01 and to-date is 2011/12/01 (means 11th, 12th months are target),
     *  the condition is: greater-equal 2011/11/03 and less-than 2012/01/03
     * 
* @param monthBeginDay The local date-time that has the day of month-begin. (NotNull) * @return this. (NotNull) */ public FromToOption beginMonth_Day(LocalDateTime monthBeginDay) { return doBeginMonth_Day(toDate(monthBeginDay)); } /** * Begin month from the specified day.
* The date of argument is used as only the day part. *
     * e.g. beginMonth_Day(toDate("2001/01/03"))
     *  month is from 3 day to 2 day of next month
     *  (the 2011/11 means 2011/11/03 to 2011/12/02)
     * 
     * e.g. option.compareAsMonth().beginMonth_Day(toDate("2001/01/03"))
     *  if from-date is 2011/11/01 and to-date is 2011/12/01 (means 11th, 12th months are target),
     *  the condition is: greater-equal 2011/11/03 and less-than 2012/01/03
     * 
* @param monthBeginDay The date that has the day of month-begin. (NotNull) * @return this. (NotNull) */ public FromToOption beginMonth_Day(Date monthBeginDay) { return doBeginMonth_Day(monthBeginDay); } protected FromToOption doBeginMonth_Day(Date monthBeginDay) { assertPatternOptionValid("beginMonth_Day"); assertArgumentNotNull("monthBeginDay", monthBeginDay); _monthBeginDay = toHandyDate(monthBeginDay).getDay(); return this; } /** * Begin month from the specified day. *
     * e.g. beginMonth_Day(3)
     *  month is from 3 day to 2 day of next month
     *  (the 2011/11 means 2011/11/03 to 2011/12/02)
     * 
     * e.g. option.compareAsMonth().beginMonth_Day(3)
     *  if from-date is 2011/11/01 and to-date is 2011/12/01 (means 11th, 12th months are target),
     *  the condition is: greater-equal 2011/11/03 and less-than 2012/01/03
     * 
* @param monthBeginDay The day for month-begin. (NotMinus, 1-31) * @return this. (NotNull) */ public FromToOption beginMonth_Day(int monthBeginDay) { assertPatternOptionValid("beginMonth_Day"); assertNotMinusNotOver("monthBeginDay", monthBeginDay, 31); _monthBeginDay = monthBeginDay; return this; } /** * Begin year from the specified day of previous month. *
     * e.g. beginMonth_PreviousDay(25)
     *  month is from 25 day of previous year to 24 day of this month
     *  (the 2011/11 means 2011/10/25 to 2011/11/24)
     * 
     * e.g. option.compareAsMonth().beginMonth_PreviousDay(25)
     *  if from-date is 2011/11/01 and to-date is 2011/12/01 (means 11th, 12th months are target),
     *  the condition is: greater-equal 2011/10/25 and less-than 2011/12/25
     * 
* @param monthBeginDay The day of previous month for month-begin. (NotMinus, 1-31) * @return this. (NotNull) */ public FromToOption beginMonth_PreviousDay(int monthBeginDay) { assertPatternOptionValid("beginMonth_PreviousDay"); assertNotMinusNotOver("monthBeginDay", monthBeginDay, 31); _monthBeginDay = -monthBeginDay; // to be minus return this; } // ----------------------------------------------------- // Begin Day // --------- /** * Begin day from the specified hour. *
     * e.g. beginDay_Hour(toLocalDate("2001/01/01 06:00:00"))
     *  day is from 06h to 05h of next day
     *  (the 2011/11/27 means 2011/11/27 06h to 2011/11/28 05h)
     * 
     * e.g. option.compareAsDate().beginDay_Hour(toLocalDate("2001/01/01 06:00:00"))
     *  if from-date is 2011/11/27 and to-date is 2011/11/28 (means 27, 28 days are target),
     *  the condition is: greater-equal 2011/11/27 06:00:00 and less-than 2011/11/28 06:00:00
     * 
* @param dayBeginHour The local date that has the hour of day-begin. (NotNull) * @return this. (NotNull) */ public FromToOption beginDay_Hour(LocalDate dayBeginHour) { return doBeginDay_Hour(toDate(dayBeginHour)); } /** * Begin day from the specified hour. *
     * e.g. beginDay_Hour(toLocalDateTime("2001/01/01 06:00:00"))
     *  day is from 06h to 05h of next day
     *  (the 2011/11/27 means 2011/11/27 06h to 2011/11/28 05h)
     * 
     * e.g. option.compareAsDate().beginDay_Hour(toLocalDateTime("2001/01/01 06:00:00"))
     *  if from-date is 2011/11/27 and to-date is 2011/11/28 (means 27, 28 days are target),
     *  the condition is: greater-equal 2011/11/27 06:00:00 and less-than 2011/11/28 06:00:00
     * 
* @param dayBeginHour The local date-time that has the hour of day-begin. (NotNull) * @return this. (NotNull) */ public FromToOption beginDay_Hour(LocalDateTime dayBeginHour) { return doBeginDay_Hour(toDate(dayBeginHour)); } /** * Begin day from the specified hour. *
     * e.g. beginDay_Hour(toDate("2001/01/01 06:00:00"))
     *  day is from 06h to 05h of next day
     *  (the 2011/11/27 means 2011/11/27 06h to 2011/11/28 05h)
     * 
     * e.g. option.compareAsDate().beginDay_Hour(toDate("2001/01/01 06:00:00"))
     *  if from-date is 2011/11/27 and to-date is 2011/11/28 (means 27, 28 days are target),
     *  the condition is: greater-equal 2011/11/27 06:00:00 and less-than 2011/11/28 06:00:00
     * 
* @param dayBeginHour The date that has the hour of day-begin. (NotNull) * @return this. (NotNull) */ public FromToOption beginDay_Hour(Date dayBeginHour) { return doBeginDay_Hour(dayBeginHour); } protected FromToOption doBeginDay_Hour(Date dayBeginHour) { assertPatternOptionValid("beginDay_Hour"); assertArgumentNotNull("dayBeginHour", dayBeginHour); _dayBeginHour = toHandyDate(dayBeginHour).getHour(); return this; } /** * Begin day from the specified hour. *
     * e.g. beginDay_Hour(6)
     *  day is from 06h to 05h of next day
     *  (the 2011/11/27 means 2011/11/27 06h to 2011/11/28 05h)
     * 
     * e.g. option.compareAsDate().beginDay_Hour(6)
     *  if from-date is 2011/11/27 and to-date is 2011/11/28 (means 27, 28 days are target),
     *  the condition is: greater-equal 2011/11/27 06:00:00 and less-than 2011/11/28 06:00:00
     * 
* @param dayBeginHour The day of day-begin. (NotMinus, 1-23) * @return this. (NotNull) */ public FromToOption beginDay_Hour(int dayBeginHour) { assertPatternOptionValid("beginDay_Hour"); assertNotMinusNotOver("dayBeginHour", dayBeginHour, 23); _dayBeginHour = dayBeginHour; return this; } /** * Begin day from the specified hour of previous day. *
     * e.g. beginDay_PreviousHour(22)
     *  day is from 22h of previous day to 21h of this day
     *  (the 2011/11/27 means 2011/11/26 22h to 2011/11/27 21h)
     * 
     * e.g. option.compareAsDate().beginDay_PreviousHour(22)
     *  if from-date is 2011/11/27 and to-date is 2011/11/28 (means 27, 28 days are target),
     *  the condition is: greater-equal 2011/11/26 22:00:00 and less-than 2011/11/27 22:00:00
     * 
* @param dayBeginHour The day of day-begin. (NotMinus, 1-23) * @return this. (NotNull) */ public FromToOption beginDay_PreviousHour(int dayBeginHour) { assertPatternOptionValid("beginDay_PreviousHour"); assertNotMinusNotOver("dayBeginHour", dayBeginHour, 23); _dayBeginHour = -dayBeginHour; // to be minus return this; } // ----------------------------------------------------- // Begin Week // ---------- /** * Begin week from the specified day of week. *
     * e.g. beginWeek_DayOfWeek(toLocalDate("2011/11/28")) *means Monday
     *  week starts Monday (the 2011/11/27 belongs the week, 2011/11/21 to 2011/11/27)
     * 
     * e.g. option.compareAsWeek().beginWeek_DayOfWeek(toLocalDate("2011/11/28")) *means Monday
     *  if from-date is 2011/11/24 and to-date is 2011/12/01 (means two weeks are target),
     *  the condition is: greater-equal 2011/11/21 and less-than 2011/12/05
     * 
* @param weekBeginDayOfWeek The local date that has the day of day-of-week-begin. (NotNull) * @return this. (NotNull) */ public FromToOption beginWeek_DayOfWeek(LocalDate weekBeginDayOfWeek) { return doBeginWeek_DayOfWeek(toDate(weekBeginDayOfWeek)); } /** * Begin week from the specified day of week. *
     * e.g. beginWeek_DayOfWeek(toLocalDateTime("2011/11/28")) *means Monday
     *  week starts Monday (the 2011/11/27 belongs the week, 2011/11/21 to 2011/11/27)
     * 
     * e.g. option.compareAsWeek().beginWeek_DayOfWeek(toLocalDateTime("2011/11/28")) *means Monday
     *  if from-date is 2011/11/24 and to-date is 2011/12/01 (means two weeks are target),
     *  the condition is: greater-equal 2011/11/21 and less-than 2011/12/05
     * 
* @param weekBeginDayOfWeek The local date-time that has the day of day-of-week-begin. (NotNull) * @return this. (NotNull) */ public FromToOption beginWeek_DayOfWeek(LocalDateTime weekBeginDayOfWeek) { return doBeginWeek_DayOfWeek(toDate(weekBeginDayOfWeek)); } /** * Begin week from the specified day of week. *
     * e.g. beginWeek_DayOfWeek(toDate("2011/11/28")) *means Monday
     *  week starts Monday (the 2011/11/27 belongs the week, 2011/11/21 to 2011/11/27)
     * 
     * e.g. option.compareAsWeek().beginWeek_DayOfWeek(toDate("2011/11/28")) *means Monday
     *  if from-date is 2011/11/24 and to-date is 2011/12/01 (means two weeks are target),
     *  the condition is: greater-equal 2011/11/21 and less-than 2011/12/05
     * 
* @param weekBeginDayOfWeek The date that has the day of day-of-week-begin. (NotNull) * @return this. (NotNull) */ public FromToOption beginWeek_DayOfWeek(Date weekBeginDayOfWeek) { return doBeginWeek_DayOfWeek(weekBeginDayOfWeek); } protected FromToOption doBeginWeek_DayOfWeek(Date weekBeginDayOfWeek) { assertPatternOptionValid("beginWeek_DayOfWeek"); assertArgumentNotNull("weekBeginDayOfWeek", weekBeginDayOfWeek); return doBeginWeek(toHandyDate(weekBeginDayOfWeek).getDayOfWeek()); } /** * Begin week from Sunday. *
     * e.g. option.compareAsWeek().beginWeek_DayOfWeek1st_Sunday()
     *  if from-date is 2011/11/24 and to-date is 2011/12/01 (means two weeks are target),
     *  the condition is: greater-equal 2011/11/20 and less-than 2011/12/04
     * 
* @return this. (NotNull) */ public FromToOption beginWeek_DayOfWeek1st_Sunday() { assertPatternOptionValid("beginWeek_DayOfWeek1st_Sunday"); return doBeginWeek(Calendar.SUNDAY); } /** * Begin week from Monday. *
     * e.g. option.compareAsWeek().beginWeek_DayOfWeek2nd_Monday()
     *  if from-date is 2011/11/24 and to-date is 2011/12/01 (means two weeks are target),
     *  the condition is: greater-equal 2011/11/21 and less-than 2011/12/05
     * 
* @return this. (NotNull) */ public FromToOption beginWeek_DayOfWeek2nd_Monday() { assertPatternOptionValid("beginWeek_DayOfWeek2nd_Monday"); return doBeginWeek(Calendar.MONDAY); } /** * Begin week from Tuesday. *
     * e.g. option.compareAsWeek().beginWeek_DayOfWeek3rd_Tuesday()
     *  if from-date is 2011/11/24 and to-date is 2011/12/01 (means two weeks are target),
     *  the condition is: greater-equal 2011/11/22 and less-than 2011/12/06
     * 
* @return this. (NotNull) */ public FromToOption beginWeek_DayOfWeek3rd_Tuesday() { assertPatternOptionValid("beginWeek_DayOfWeek3rd_Tuesday"); return doBeginWeek(Calendar.TUESDAY); } /** * Begin week from Wednesday. *
     * e.g. option.compareAsWeek().beginWeek_DayOfWeek4th_Wednesday()
     *  if from-date is 2011/11/24 and to-date is 2011/12/01 (means two weeks are target),
     *  the condition is: greater-equal 2011/11/23 and less-than 2011/12/07
     * 
* @return this. (NotNull) */ public FromToOption beginWeek_DayOfWeek4th_Wednesday() { assertPatternOptionValid("beginWeek_DayOfWeek4th_Wednesday"); return doBeginWeek(Calendar.WEDNESDAY); } /** * Begin week from Thursday. *
     * e.g. option.compareAsWeek().beginWeek_DayOfWeek5th_Thursday()
     *  if from-date is 2011/11/24 and to-date is 2011/12/01 (means two weeks are target),
     *  the condition is: greater-equal 2011/11/24 and less-than 2011/12/08
     * 
* @return this. (NotNull) */ public FromToOption beginWeek_DayOfWeek5th_Thursday() { assertPatternOptionValid("beginWeek_DayOfWeek5th_Thursday"); return doBeginWeek(Calendar.THURSDAY); } /** * Begin week from Friday. *
     * e.g. option.compareAsWeek().beginWeek_DayOfWeek6th_Friday()
     *  if from-date is 2011/11/24 and to-date is 2011/12/01 (means two weeks are target),
     *  the condition is: greater-equal 2011/11/18 and less-than 2011/12/02
     * 
* @return this. (NotNull) */ public FromToOption beginWeek_DayOfWeek6th_Friday() { assertPatternOptionValid("beginWeek_DayOfWeek6th_Friday"); return doBeginWeek(Calendar.FRIDAY); } /** * Begin week from Saturday. *
     * e.g. option.compareAsWeek().beginWeek_DayOfWeek7th_Saturday()
     *  if from-date is 2011/11/24 and to-date is 2011/12/01 (means two weeks are target),
     *  the condition is: greater-equal 2011/11/19 and less-than 2011/12/03
     * 
* @return this. (NotNull) */ public FromToOption beginWeek_DayOfWeek7th_Saturday() { assertPatternOptionValid("beginWeek_DayOfWeek7th_Saturday"); return doBeginWeek(Calendar.SATURDAY); } protected FromToOption doBeginWeek(int weekBeginDayOfWeek) { _weekBeginDay = weekBeginDayOfWeek; return this; } // ----------------------------------------------------- // Move-to Scope // ------------- /** * Move to the specified count of scope. *
     * e.g.
     *  compareAsYear().moveToScope(-1): 2011 to 2010 year
     *  compareAsMonth().moveToScope(-1): 11th to 10th month
     *  compareAsDate().moveToScope(2): 27 to 29 day
     *  compareAsHour().moveToScope(7): 12 to 19 hour
     * 
     * e.g. compareAsDate().moveToScope(-1)
     *  if both from-date and to-date are 2011/11/27,
     *  the condition is: greater-equal 2011/11/26 and less-than 2011/11/27
     * 
     *  if both from-date is 2011/11/26 and to-date is 2011/11/28,
     *  the condition is: greater-equal 2011/11/25 and less-than 2011/11/28 
     * 
     * e.g. compareAsDate() *normal (no move-to scope)
     *  if both from-date and to-date are 2011/11/27,
     *  the condition is: greater-equal 2011/11/27 and less-than 2011/11/28
     * 
     *  if both from-date is 2011/11/26 and to-date is 2011/11/28,
     *  the condition is: greater-equal 2011/11/26 and less-than 2011/11/29 
     * 
* @param moveToCount The count to move-to. (MinusAllowed) * @return this. (NotNull) */ public FromToOption moveToScope(int moveToCount) { assertPatternOptionValid("moveToScope"); _moveToScope = moveToCount; return this; } // =================================================================================== // Manual Adjustment // ================= // ----------------------------------------------------- // All // --- protected void clearAll() { clearOperand(); clearFromPattern(); clearToPattern(); clearFromDateWith(); clearToDateWith(); _usePattern = false; } // ----------------------------------------------------- // Operand // ------- /** * Set up operand for from-date as greater-than.
* This is for manual adjustment. * @return this. (NotNull) */ public FromToOption greaterThan() { assertNotAdjustmentAfterPattern("greaterThan"); _greaterThan = true; return this; } /** * Set up operand for to-date as less-than.
* This is for manual adjustment. * @return this. (NotNull) */ public FromToOption lessThan() { assertNotAdjustmentAfterPattern("lessThan"); _lessThan = true; return this; } public boolean isGreaterThan() { // basically for framework return _greaterThan; } public boolean isLessThan() { // basically for framework return _lessThan; } protected void clearOperand() { _greaterThan = false; _lessThan = false; } // ----------------------------------------------------- // From Date // --------- public FromToOption fromPatternHourJust() { assertNotAdjustmentAfterPattern("fromPatternHourJust"); clearFromPattern(); _fromPatternHourJust = true; return this; } public FromToOption fromPatternDayJust() { assertNotAdjustmentAfterPattern("fromPatternDayJust"); clearFromPattern(); _fromPatternDayJust = true; return this; } public FromToOption fromPatternMonthJust() { assertNotAdjustmentAfterPattern("fromPatternMonthJust"); clearFromPattern(); _fromPatternMonthJust = true; return this; } public FromToOption fromPatternYearJust() { assertNotAdjustmentAfterPattern("fromPatternYearJust"); clearFromPattern(); _fromPatternYearJust = true; return this; } public FromToOption fromPatternWeekJust() { assertNotAdjustmentAfterPattern("fromPatternWeekJust"); clearFromPattern(); _fromPatternWeekJust = true; return this; } public FromToOption fromPatternQuarterOfYearJust() { assertNotAdjustmentAfterPattern("fromPatternQuarterOfYearJust"); clearFromPattern(); _fromPatternQuarterOfYearJust = true; return this; } protected void clearFromPattern() { _fromPatternHourJust = false; _fromPatternDayJust = false; _fromPatternMonthJust = false; _fromPatternYearJust = false; _fromPatternWeekJust = false; _fromPatternQuarterOfYearJust = false; } public FromToOption fromDateWithNoon() { clearFromDateWith(); _fromDateWithNoon = true; return this; } public FromToOption fromDateWithHour(int hourOfDay) { clearFromDateWith(); _fromDateWithHour = hourOfDay; return this; } protected void clearFromDateWith() { _fromDateWithNoon = false; _fromDateWithHour = null; } // ----------------------------------------------------- // To Date // ------- public FromToOption toPatternNextHourJust() { assertNotAdjustmentAfterPattern("toPatternNextHourJust"); clearToPattern(); _toPatternNextHourJust = true; return this; } public FromToOption toPatternNextDayJust() { assertNotAdjustmentAfterPattern("toPatternNextDayJust"); clearToPattern(); _toPatternNextDayJust = true; return this; } public FromToOption toPatternNextMonthJust() { assertNotAdjustmentAfterPattern("toPatternNextMonthBegin"); clearToPattern(); _toPatternNextMonthJust = true; return this; } public FromToOption toPatternNextYearJust() { assertNotAdjustmentAfterPattern("toPatternNextYearJust"); clearToPattern(); _toPatternNextYearJust = true; return this; } public FromToOption toPatternNextWeekJust() { assertNotAdjustmentAfterPattern("toPatternNextWeekJust"); clearToPattern(); _toPatternNextWeekJust = true; return this; } public FromToOption toPatternNextQuarterOfYearJust() { assertNotAdjustmentAfterPattern("toPatternNextQuarterOfYearJust"); clearToPattern(); _toPatternNextQuarterOfYearJust = true; return this; } protected void clearToPattern() { _toPatternNextHourJust = false; _toPatternNextDayJust = false; _toPatternNextMonthJust = false; _toPatternNextYearJust = false; _toPatternNextWeekJust = false; _toPatternNextQuarterOfYearJust = false; } public FromToOption toDateWithNoon() { clearToDateWith(); _toDateWithNoon = true; return this; } public FromToOption toDateWithHour(int hourOfDay) { clearToDateWith(); _toDateWithHour = hourOfDay; return this; } protected void clearToDateWith() { _toDateWithNoon = false; _toDateWithHour = null; } // =================================================================================== // Plug-in Option // ============== /** * Add 'or is null' to from-to conditions. * @return this. (NotNull) */ public FromToOption orIsNull() { _orIsNull = true; return this; } /** * Does it add or-is-null to the condition? * @return The determination, true or false. */ public boolean isOrIsNull() { // basically for framework return _orIsNull; } /** * Allow you to set one-side only condition. (null allowed)
* If you ignore null-or-empty query, you don't need to call this. * @return this. (NotNull) */ public FromToOption allowOneSide() { _oneSideAllowed = true; return this; } /** * Does it allow you to set one-side only condition.
* @return The determination, true or false. */ public boolean isOneSideAllowed() { return _oneSideAllowed; } // =================================================================================== // Filte Date // ========== public LocalDate filterFromDate(LocalDate fromDate) { // #dateParade final TimeZone timeZone = DBFluteSystem.getFinalTimeZone(); return DfTypeUtil.toLocalDate(filterFromDate(DfTypeUtil.toDate(fromDate, timeZone)), timeZone); } /** * Filter the date as From. It requires this method is called before getFromDateConditionKey(). * @param The type of (util)Date. * @param fromDate The date as From. (NullAllowed: If the value is null, it returns null) * @return The filtered date as From. (NullAllowed) */ public DATE filterFromDate(DATE fromDate) { if (fromDate == null) { return null; } final Calendar cal = Calendar.getInstance(); cal.setTimeInMillis(fromDate.getTime()); if (_fromPatternYearJust) { moveToCalendarYearJust(cal); moveToScopeYear(cal); } else if (_fromPatternMonthJust) { moveToCalendarMonthJust(cal); moveToScopeMonth(cal); } else if (_fromPatternDayJust) { moveToCalendarDayJust(cal); moveToScopeDay(cal); } else if (_fromPatternHourJust) { moveToCalendarHourJust(cal); moveToScopeHour(cal); } else if (_fromPatternWeekJust) { moveToCalendarWeekJust(cal); moveToScopeWeek(cal); } else if (_fromPatternQuarterOfYearJust) { moveToCalendarQuarterOfYearJust(cal); moveToScopeQuarterOfYear(cal); } if (_fromDateWithNoon) { moveToCalendarHourJustNoon(cal); } if (_fromDateWithHour != null) { moveToCalendarHourJustFor(cal, _fromDateWithHour); } @SuppressWarnings("unchecked") final DATE cloneDate = (DATE) fromDate.clone(); cloneDate.setTime(cal.getTimeInMillis()); fromDate = cloneDate; return fromDate; } /** * Filter the date as To. It requires this method is called before getToDateConditionKey(). * @param The type of sub-class for java.util.Date. * @param toDate The date as To. (NullAllowed: If the value is null, it returns null) * @return The filtered date as To. (NullAllowed) */ public DATE filterToDate(DATE toDate) { if (toDate == null) { return null; } final Calendar cal = Calendar.getInstance(); cal.setTimeInMillis(toDate.getTime()); if (_toPatternNextYearJust) { moveToCalendarNextYearJust(cal); moveToScopeYear(cal); } else if (_toPatternNextMonthJust) { moveToCalendarNextMonthJust(cal); moveToScopeMonth(cal); } else if (_toPatternNextDayJust) { moveToCalendarNextDayJust(cal); moveToScopeDay(cal); } else if (_toPatternNextHourJust) { moveToCalendarNextHourJust(cal); moveToScopeHour(cal); } else if (_toPatternNextWeekJust) { moveToCalendarNextWeekJust(cal); moveToScopeWeek(cal); } else if (_toPatternNextQuarterOfYearJust) { moveToCalendarNextQuarterOfYearJust(cal); moveToScopeQuarterOfYear(cal); } if (_toDateWithNoon) { moveToCalendarHourJustNoon(cal); } if (_toDateWithHour != null) { moveToCalendarHourJustFor(cal, _toDateWithHour); } @SuppressWarnings("unchecked") final DATE cloneDate = (DATE) toDate.clone(); cloneDate.setTime(cal.getTimeInMillis()); toDate = cloneDate; return toDate; } public Date xfilterToDateBetweenWay(Date toDate) { if (toDate == null) { return null; } final Calendar cal = Calendar.getInstance(); cal.setTimeInMillis(toDate.getTime()); // moveToScope first because of using terminal if (_toPatternNextYearJust) { moveToScopeYear(cal); moveToCalendarYearTerminal(cal); } else if (_toPatternNextMonthJust) { moveToScopeMonth(cal); moveToCalendarMonthTerminal(cal); } else if (_toPatternNextDayJust) { moveToScopeDay(cal); moveToCalendarDayTerminal(cal); } else if (_toPatternNextHourJust) { moveToScopeHour(cal); moveToCalendarHourTerminal(cal); } else if (_toPatternNextWeekJust) { moveToScopeWeek(cal); moveToCalendarWeekTerminal(cal); } else if (_toPatternNextQuarterOfYearJust) { moveToScopeQuarterOfYear(cal); moveToCalendarQuarterOfYearTerminal(cal); } if (_toDateWithNoon) { moveToCalendarHourJustNoon(cal); } if (_toDateWithHour != null) { moveToCalendarHourJustFor(cal, _toDateWithHour); } final Date cloneDate = (Date) toDate.clone(); cloneDate.setTime(cal.getTimeInMillis()); toDate = cloneDate; return toDate; } protected Date filterNoon(Date date) { final Calendar cal = Calendar.getInstance(); cal.setTimeInMillis(date.getTime()); moveToCalendarHourJustNoon(cal); final Date cloneDate = (Date) date.clone(); cloneDate.setTime(cal.getTimeInMillis()); return cloneDate; } /** * Get the condition-key of the from-date. It requires this method is called after filterFromDate(). * @return The condition-key of the from-date. (NotNull) */ public ConditionKey getFromDateConditionKey() { if (_greaterThan) { return _orIsNull ? ConditionKey.CK_GREATER_THAN_OR_IS_NULL : ConditionKey.CK_GREATER_THAN; } else { // as default return _orIsNull ? ConditionKey.CK_GREATER_EQUAL_OR_IS_NULL : ConditionKey.CK_GREATER_EQUAL; } } /** * Get the condition-key of the to-date. It requires this method is called after filterToDate(). * @return The condition-key of the to-date. (NotNull) */ public ConditionKey getToDateConditionKey() { if (_lessThan) { return _orIsNull ? ConditionKey.CK_LESS_THAN_OR_IS_NULL : ConditionKey.CK_LESS_THAN; } else { // as default return _orIsNull ? ConditionKey.CK_LESS_EQUAL_OR_IS_NULL : ConditionKey.CK_LESS_EQUAL; } } // =================================================================================== // Calendar Helper // =============== // ----------------------------------------------------- // Move-to Just // ------------ protected void moveToCalendarYearJust(Calendar cal) { DfTypeUtil.moveToCalendarYearJust(cal, _yearBeginMonth); } protected void moveToCalendarMonthJust(Calendar cal) { DfTypeUtil.moveToCalendarMonthJust(cal, _monthBeginDay); } protected void moveToCalendarDayJust(Calendar cal) { DfTypeUtil.moveToCalendarDayJust(cal, _dayBeginHour); } protected void moveToCalendarHourJust(Calendar cal) { DfTypeUtil.moveToCalendarHourJust(cal); } protected void moveToCalendarHourJustFor(Calendar cal, int hourOfDay) { DfTypeUtil.moveToCalendarHourJustFor(cal, hourOfDay); } protected void moveToCalendarHourJustNoon(Calendar cal) { DfTypeUtil.moveToCalendarHourJustNoon(cal); } protected void moveToCalendarWeekJust(Calendar cal) { DfTypeUtil.moveToCalendarWeekJust(cal, _weekBeginDay); } protected void moveToCalendarQuarterOfYearJust(Calendar cal) { DfTypeUtil.moveToCalendarQuarterOfYearJust(cal, _yearBeginMonth); } // ----------------------------------------------------- // Move-to Next // ------------ protected void moveToCalendarNextYearJust(Calendar cal) { moveToCalendarYearTerminal(cal); addCalendarMillisecondOne(cal); } protected void moveToCalendarNextMonthJust(Calendar cal) { moveToCalendarMonthTerminal(cal); addCalendarMillisecondOne(cal); } protected void moveToCalendarNextDayJust(Calendar cal) { moveToCalendarDayTerminal(cal); addCalendarMillisecondOne(cal); } protected void moveToCalendarNextHourJust(Calendar cal) { moveToCalendarHourTerminal(cal); addCalendarMillisecondOne(cal); } protected void moveToCalendarNextWeekJust(Calendar cal) { moveToCalendarWeekTerminal(cal); addCalendarMillisecondOne(cal); } protected void moveToCalendarNextQuarterOfYearJust(Calendar cal) { moveToCalendarQuarterOfYearTerminal(cal); addCalendarMillisecondOne(cal); } protected void addCalendarMillisecondOne(Calendar cal) { DfTypeUtil.addCalendarMillisecond(cal, 1); } // ----------------------------------------------------- // Move-to Terminal // ---------------- protected void moveToCalendarYearTerminal(Calendar cal) { DfTypeUtil.moveToCalendarYearTerminal(cal, _yearBeginMonth); } protected void moveToCalendarMonthTerminal(Calendar cal) { DfTypeUtil.moveToCalendarMonthTerminal(cal, _monthBeginDay); } protected void moveToCalendarDayTerminal(Calendar cal) { DfTypeUtil.moveToCalendarDayTerminal(cal, _dayBeginHour); } protected void moveToCalendarHourTerminal(Calendar cal) { DfTypeUtil.moveToCalendarHourTerminal(cal); } protected void moveToCalendarWeekTerminal(Calendar cal) { DfTypeUtil.moveToCalendarWeekTerminal(cal, _weekBeginDay); } protected void moveToCalendarQuarterOfYearTerminal(Calendar cal) { DfTypeUtil.moveToCalendarQuarterOfYearTerminal(cal, _yearBeginMonth); } // ----------------------------------------------------- // Move-to Scope // ------------- protected void moveToScopeYear(Calendar cal) { if (_moveToScope != null) { DfTypeUtil.addCalendarYear(cal, _moveToScope); } } protected void moveToScopeMonth(Calendar cal) { if (_moveToScope != null) { DfTypeUtil.addCalendarMonth(cal, _moveToScope); } } protected void moveToScopeDay(Calendar cal) { if (_moveToScope != null) { DfTypeUtil.addCalendarDay(cal, _moveToScope); } } protected void moveToScopeHour(Calendar cal) { if (_moveToScope != null) { DfTypeUtil.addCalendarHour(cal, _moveToScope); } } protected void moveToScopeWeek(Calendar cal) { if (_moveToScope != null) { DfTypeUtil.addCalendarWeek(cal, _moveToScope); } } protected void moveToScopeQuarterOfYear(Calendar cal) { if (_moveToScope != null) { DfTypeUtil.addCalendarQuarterOfYear(cal, _moveToScope); } } // =================================================================================== // TimeZone // ======== /** * Set time-zone, basically for LocalDate conversion.
* Normally you don't need to set this, you can adjust other ways.
* (DBFlute system's time-zone is used as default) * @param timeZone The time-zone for filtering. (NullAllowed: if null, default zone) * @return this. (NotNull) */ public FromToOption zone(TimeZone timeZone) { _timeZone = timeZone; return this; } /** * Get the time-zone in this option basically for filtering. * @return The time-zone for filtering. (NotNull: if no setting, system zone) */ public TimeZone getTimeZone() { return _timeZone != null ? _timeZone : getDBFluteSystemFinalTimeZone(); } protected TimeZone getDBFluteSystemFinalTimeZone() { return DBFluteSystem.getFinalTimeZone(); } // =================================================================================== // Interface Implementation // ======================== public String getRearOption() { return ""; } public boolean hasCompoundColumn() { return false; } public List getCompoundColumnList() { return DfCollectionUtil.emptyList(); } public boolean hasStringConnector() { return false; } public OnQueryStringConnector getStringConnector() { return null; } public ExtensionOperand getExtensionOperand() { return null; } public QueryClauseArranger getWhereClauseArranger() { return null; } public GearedCipherManager getGearedCipherManager() { return null; } // =================================================================================== // Small Helper // ============ protected Date toDate(LocalDate date) { return DfTypeUtil.toDate(date, getTimeZone()); } protected Date toDate(LocalDateTime date) { return DfTypeUtil.toDate(date, getTimeZone()); } protected HandyDate toHandyDate(Date date) { return new HandyDate(date).timeZone(getTimeZone()); } // =================================================================================== // Assert Helper // ============= protected void assertArgumentNotNull(String name, Object value) { if (value == null) { String msg = "The argument '" + name + "' should not be null."; throw new IllegalArgumentException(msg); } } protected void assertNotMinusNotOver(String name, int value, int max) { if (value < 0) { String msg = "The argument '" + name + "' should not be minus: value=" + value; throw new IllegalArgumentException(msg); } if (value > max) { String msg = "The argument '" + name + "' should not be over: value=" + value + " max=" + max; throw new IllegalArgumentException(msg); } } protected void assertPatternOptionValid(String option) { if (!_usePattern) { String msg = "The option '" + option + "()' should be called after pattern setting."; throw new IllegalStateException(msg); } } protected void assertNotAdjustmentAfterPattern(String option) { if (_usePattern) { String msg = "The option '" + option + "()' should not be call after pattern setting."; throw new IllegalStateException(msg); } } // =================================================================================== // Basic Override // ============== @Override public String toString() { final String title = DfTypeUtil.toClassTitle(this); final StringBuilder sb = new StringBuilder(); sb.append(title); sb.append(":{usePattern=").append(_usePattern); sb.append(", greaterThan=").append(_greaterThan).append(", lessThan=").append(_lessThan); sb.append(", orIsNull=").append(_orIsNull); sb.append(", oneSideAllowed=").append(_oneSideAllowed); sb.append("}"); return sb.toString(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy