/* * Copyright 2001-2005 Stephen Colebourne * * 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.joda.time.chrono.gj; import org.joda.time.DateTimeFieldType; import org.joda.time.DurationField; /** * * @author Brian S O'Neill */ class TestGJMonthOfYearField extends TestGJDateTimeField { public TestGJMonthOfYearField(TestGJChronology chrono) { super(DateTimeFieldType.monthOfYear(), chrono.millisPerMonth(), chrono); } public int get(long millis) { return iChronology.gjFromMillis(millis)[1]; } public long set(long millis, int value) { long timeOnlyMillis = iChronology.getTimeOnlyMillis(millis); int[] ymd = iChronology.gjFromMillis(millis); // First set to start of month... millis = iChronology.millisFromGJ(ymd[0], value, 1); // ...and use dayOfMonth field to check range. int maxDay = iChronology.dayOfMonth().getMaximumValue(millis); if (ymd[2] > maxDay) { ymd[2] = maxDay; } return timeOnlyMillis + iChronology.millisFromGJ(ymd[0], value, ymd[2]); } public long add(long millis, long value) { int newYear = iChronology.year().get(millis) + (int)TestGJChronology.div(value, 12); int newMonth = get(millis) + (int)TestGJChronology.mod(value, 12); if (newMonth > 12) { newYear++; newMonth -= 12; } int newDay = iChronology.dayOfMonth().get(millis); millis = iChronology.getTimeOnlyMillis(millis) + iChronology.millisFromGJ(newYear, newMonth, newDay); while (get(millis) != newMonth) { millis = iChronology.dayOfYear().add(millis, -1); } return millis; } public boolean isLeap(long millis) { int[] ymd = iChronology.gjFromMillis(millis); return ymd[1] == 2 && iChronology.isLeapYear(ymd[0]); } public int getLeapAmount(long millis) { return isLeap(millis) ? 1 : 0; } public DurationField getLeapDurationField() { return iChronology.days(); } public DurationField getRangeDurationField() { return iChronology.years(); } public int getMinimumValue() { return 1; } public int getMaximumValue() { return 12; } public long roundFloor(long millis) { int[] ymd = iChronology.gjFromMillis(millis); return iChronology.millisFromGJ(ymd[0], ymd[1], 1); } }