diff --git a/.mvn/wrapper/MavenWrapperDownloader.java b/.mvn/wrapper/MavenWrapperDownloader.java index b901097f..d6cbe47d 100644 --- a/.mvn/wrapper/MavenWrapperDownloader.java +++ b/.mvn/wrapper/MavenWrapperDownloader.java @@ -54,7 +54,7 @@ public static void main(String args[]) { // wrapperUrl parameter. File mavenWrapperPropertyFile = new File(baseDirectory, MAVEN_WRAPPER_PROPERTIES_PATH); String url = DEFAULT_DOWNLOAD_URL; - if(mavenWrapperPropertyFile.exists()) { + if (mavenWrapperPropertyFile.exists()) { FileInputStream mavenWrapperPropertyFileInputStream = null; try { mavenWrapperPropertyFileInputStream = new FileInputStream(mavenWrapperPropertyFile); @@ -65,7 +65,7 @@ public static void main(String args[]) { System.out.println("- ERROR loading '" + MAVEN_WRAPPER_PROPERTIES_PATH + "'"); } finally { try { - if(mavenWrapperPropertyFileInputStream != null) { + if (mavenWrapperPropertyFileInputStream != null) { mavenWrapperPropertyFileInputStream.close(); } } catch (IOException e) { @@ -76,8 +76,8 @@ public static void main(String args[]) { System.out.println("- Downloading from: " + url); File outputFile = new File(baseDirectory.getAbsolutePath(), MAVEN_WRAPPER_JAR_PATH); - if(!outputFile.getParentFile().exists()) { - if(!outputFile.getParentFile().mkdirs()) { + if (!outputFile.getParentFile().exists()) { + if (!outputFile.getParentFile().mkdirs()) { System.out.println( "- ERROR creating output directory '" + outputFile.getParentFile().getAbsolutePath() + "'"); } diff --git a/src/main/java/com/kosherjava/zmanim/AstronomicalCalendar.java b/src/main/java/com/kosherjava/zmanim/AstronomicalCalendar.java index 8714fcfc..914770a9 100644 --- a/src/main/java/com/kosherjava/zmanim/AstronomicalCalendar.java +++ b/src/main/java/com/kosherjava/zmanim/AstronomicalCalendar.java @@ -621,7 +621,7 @@ public double getSunriseSolarDipFromOffset(double minutes) { while (offsetByDegrees == null || ((minutes < 0.0 && offsetByDegrees.getTime() < offsetByTime.getTime()) || (minutes > 0.0 && offsetByDegrees.getTime() > offsetByTime.getTime()))) { - if(minutes > 0.0) { + if (minutes > 0.0) { degrees = degrees.add(incrementor); } else { degrees = degrees.subtract(incrementor); @@ -649,7 +649,7 @@ public double getSunsetSolarDipFromOffset(double minutes) { BigDecimal incrementor = new BigDecimal("0.001"); while (offsetByDegrees == null || ((minutes > 0.0 && offsetByDegrees.getTime() < offsetByTime.getTime()) || (minutes < 0.0 && offsetByDegrees.getTime() > offsetByTime.getTime()))) { - if(minutes > 0.0) { + if (minutes > 0.0) { degrees = degrees.add(incrementor); } else { degrees = degrees.subtract(incrementor); @@ -677,7 +677,7 @@ public double getSunsetSolarDipFromOffset(double minutes) { * @see GeoLocation#getLocalMeanTimeOffset() */ public Date getLocalMeanTime(double hours) { - if(hours < 0 || hours >= 24) { + if (hours < 0 || hours >= 24) { throw new IllegalArgumentException("Hours must between 0 and 23.9999..."); } return getTimeOffset(getDateFromTime(hours - getGeoLocation().getTimeZone().getRawOffset() @@ -832,9 +832,11 @@ public Object clone() { } catch (CloneNotSupportedException cnse) { // Required by the compiler. Should never be reached since we implement clone() } - clone.setGeoLocation((GeoLocation) getGeoLocation().clone()); - clone.setCalendar((Calendar) getCalendar().clone()); - clone.setAstronomicalCalculator((AstronomicalCalculator) getAstronomicalCalculator().clone()); + if (clone != null) { + clone.setGeoLocation((GeoLocation) getGeoLocation().clone()); + clone.setCalendar((Calendar) getCalendar().clone()); + clone.setAstronomicalCalculator((AstronomicalCalculator) getAstronomicalCalculator().clone()); + } return clone; } } diff --git a/src/main/java/com/kosherjava/zmanim/ComplexZmanimCalendar.java b/src/main/java/com/kosherjava/zmanim/ComplexZmanimCalendar.java index 070ccf1e..0f3fcc74 100644 --- a/src/main/java/com/kosherjava/zmanim/ComplexZmanimCalendar.java +++ b/src/main/java/com/kosherjava/zmanim/ComplexZmanimCalendar.java @@ -1821,7 +1821,7 @@ public Date getMinchaGedola30Minutes() { * {@link AstronomicalCalendar} documentation. */ public Date getMinchaGedola72Minutes() { - if(isUseAstronomicalChatzosForOtherZmanim()) { + if (isUseAstronomicalChatzosForOtherZmanim()) { return getHalfDayBasedZman(getChatzos(), getTzais72(), 0.5); } else { return getMinchaGedola(getAlos72(), getTzais72(), true); @@ -1846,7 +1846,7 @@ public Date getMinchaGedola72Minutes() { * See detailed explanation on top of the {@link AstronomicalCalendar} documentation. */ public Date getMinchaGedola16Point1Degrees() { - if(isUseAstronomicalChatzosForOtherZmanim()) { + if (isUseAstronomicalChatzosForOtherZmanim()) { return getHalfDayBasedZman(getChatzos(), getTzais16Point1Degrees(), 0.5); } else { return getMinchaGedola(getAlos16Point1Degrees(), getTzais16Point1Degrees(), true); @@ -3800,6 +3800,36 @@ public Date getSofZmanAchilasChametzMGA72Minutes() { return getSofZmanTfilaMGA72Minutes(); } + /** + * This method returns the latest time one is allowed eating chametz on Erev Pesach according to the + * opinion of the Magen Avraham (MGA) based on alos + * being {@link #getAlos72Zmanis() 72 zmaniyos} minutes before {@link #getSunrise() sunrise}. This time is identical to the + * {@link #getSofZmanTfilaMGA72MinutesZmanis() Sof zman tfilah MGA 72 minutes zmanis}. This time is 4 {@link #getShaahZmanis72MinutesZmanis() + * shaos zmaniyos} (temporal hours) after {@link #getAlos72() dawn} based on the opinion of the MGA that the day is + * calculated from a {@link #getAlos72Zmanis() dawn} of 72 minutes zmanis before sunrise to {@link #getTzais72Zmanis() nightfall} of 72 minutes zmanis + * after sunset. This returns the time of 4 * {@link #getShaahZmanis72MinutesZmanis()} after {@link #getAlos72Zmanis() dawn}. If it is not + * erev Pesach, a null will be returned. + * + * @return the Date of the latest time of eating chametz. If it is not erev Pesach or the + * calculation can't be computed such as in the Arctic Circle where there is at least one day a year where the sun does + * not rise, and one where it does not set), a null will be returned. See detailed explanation on top of + * the {@link AstronomicalCalendar} documentation. + * @todo in v 3.0.0 enable the calendar check for erev pesach and return null in all other cases. + * @see #getShaahZmanis72MinutesZmanis() + * @see #getAlos72Zmanis() + * @see #getSofZmanTfilaMGA72MinutesZmanis() + */ + public Date getSofZmanAchilasChametzMGA72MinutesZmanis() { + JewishCalendar jewishCalendar = new JewishCalendar(); + jewishCalendar.setGregorianDate(getCalendar().get(Calendar.YEAR), getCalendar().get(Calendar.MONTH), + getCalendar().get(Calendar.DAY_OF_MONTH)); + if (jewishCalendar.getJewishMonth() == JewishCalendar.NISSAN && jewishCalendar.getJewishDayOfMonth() == 14) { + return getSofZmanTfilaMGA72MinutesZmanis(); + } else { + return null; + } + } + /** * This method returns the latest time one is allowed eating chametz on Erev Pesach according to the * opinion of theMagen Avraham (MGA) based on alos @@ -3886,7 +3916,35 @@ public Date getSofZmanBiurChametzMGA72Minutes() { } /** - * FIXME adjust for synchronous + * FIXME adjust for syncronous + * This method returns the latest time for burning chametz on Erev Pesach according to the opinion of + * the Magen Avraham (MGA) based on alos + * being {@link #getAlos72Zmanis() 72} minutes zmanis before {@link #getSunrise() sunrise}. This time is 5 {@link + * #getShaahZmanis72MinutesZmanis() shaos zmaniyos} (temporal hours) after {@link #getAlos72Zmanis() dawn} based on the opinion of + * the MGA that the day is calculated from a {@link #getAlos72Zmanis() dawn} of 72 minutes zmanis before sunrise to {@link + * #getTzais72Zmanis() nightfall} of 72 minutes zmanis after sunset. This returns the time of 5 * {@link #getShaahZmanis72MinutesZmanis()} after + * {@link #getAlos72Zmanis() dawn}. If it is not erev Pesach, a null will be returned. + * @todo in v 3.0.0 enable the calendar check for erev pesach and return null in all other cases. + * @return the Date of the latest time for burning chametz on Erev Pesach. If it is not + * erev Pesach or the calculation can't be computed such as in the Arctic Circle where there is at + * least one day a year where the sun does not rise, and one where it does not set), a null will be + * returned. See detailed explanation on top of the {@link AstronomicalCalendar} documentation. + * @see #getShaahZmanis72MinutesZmanis() + * @see #getAlos72Zmanis() + */ + public Date getSofZmanBiurChametzMGA72MinutesZmanis() { + JewishCalendar jewishCalendar = new JewishCalendar(); + jewishCalendar.setGregorianDate(getCalendar().get(Calendar.YEAR), getCalendar().get(Calendar.MONTH), + getCalendar().get(Calendar.DAY_OF_MONTH)); + if (jewishCalendar.getJewishMonth() == JewishCalendar.NISSAN && jewishCalendar.getJewishDayOfMonth() == 14) { + return getTimeOffset(getAlos72Zmanis(), getShaahZmanis72MinutesZmanis() * 5); + } else { + return null; + } + } + + /** + * FIXME adjust for syncronous * This method returns the latest time for burning chametz on Erev Pesach according to the opinion * of the Magen Avraham (MGA) based on alos * being {@link #getAlos16Point1Degrees() 16.1°} before {@link #getSunrise() sunrise}. This time is 5 diff --git a/src/main/java/com/kosherjava/zmanim/ZmanimCalendar.java b/src/main/java/com/kosherjava/zmanim/ZmanimCalendar.java index a952c077..47a42513 100644 --- a/src/main/java/com/kosherjava/zmanim/ZmanimCalendar.java +++ b/src/main/java/com/kosherjava/zmanim/ZmanimCalendar.java @@ -266,7 +266,7 @@ public void setUseAstronomicalChatzosForOtherZmanim(boolean useAstronomicalChatz * @see com.kosherjava.zmanim.AstronomicalCalendar#getSunrise() */ protected Date getElevationAdjustedSunrise() { - if(isUseElevation()) { + if (isUseElevation()) { return super.getSunrise(); } return getSeaLevelSunrise(); @@ -282,7 +282,7 @@ protected Date getElevationAdjustedSunrise() { * @see com.kosherjava.zmanim.AstronomicalCalendar#getSunset() */ protected Date getElevationAdjustedSunset() { - if(isUseElevation()) { + if (isUseElevation()) { return super.getSunset(); } return getSeaLevelSunset(); @@ -370,11 +370,11 @@ public Date getAlos72() { * See detailed explanation on top of the {@link AstronomicalCalendar} documentation. */ public Date getChatzos() { - if(useAstronomicalChatzos) { + if (useAstronomicalChatzos) { return getSunTransit(); // can be null of the calculator does not support astronomical chatzos } else { Date halfDayChatzos = getChatzosAsHalfDay(); - if(halfDayChatzos == null) { + if (halfDayChatzos == null) { return getSunTransit(); // can be null if the calculator does not support astronomical chatzos } else { return halfDayChatzos; @@ -447,7 +447,7 @@ public Date getChatzosAsHalfDay() { * detailed explanation on top of the {@link AstronomicalCalendar} documentation. */ public Date getSofZmanShma(Date startOfDay, Date endOfDay, boolean synchronous) { - if(isUseAstronomicalChatzosForOtherZmanim() && synchronous) { + if (isUseAstronomicalChatzosForOtherZmanim() && synchronous) { return getHalfDayBasedZman(startOfDay, getChatzos(), 3); } else { return getShaahZmanisBasedZman(startOfDay, endOfDay, 3); @@ -588,7 +588,7 @@ public Date getCandleLighting() { * returned. See detailed explanation on top of the {@link AstronomicalCalendar} documentation. */ public Date getSofZmanTfila(Date startOfDay, Date endOfDay, boolean synchronous) { - if(isUseAstronomicalChatzosForOtherZmanim() && synchronous) { + if (isUseAstronomicalChatzosForOtherZmanim() && synchronous) { return getHalfDayBasedZman(startOfDay, getChatzos(), 4); } else { return getShaahZmanisBasedZman(startOfDay, endOfDay, 4); @@ -697,7 +697,7 @@ public Date getSofZmanTfilaMGA() { * @see #isUseAstronomicalChatzosForOtherZmanim() */ public Date getMinchaGedola(Date startOfDay, Date endOfDay, boolean synchronous) { - if(isUseAstronomicalChatzosForOtherZmanim() && synchronous) { + if (isUseAstronomicalChatzosForOtherZmanim() && synchronous) { return getHalfDayBasedZman(getChatzos(), endOfDay, 0.5); } else { return getShaahZmanisBasedZman(startOfDay, endOfDay, 6.5); @@ -784,7 +784,7 @@ public Date getMinchaGedola() { * @see ComplexZmanimCalendar#getSamuchLeMinchaKetana72Minutes() */ public Date getSamuchLeMinchaKetana(Date startOfDay, Date endOfDay, boolean synchronous) { - if(isUseAstronomicalChatzosForOtherZmanim() && synchronous) { + if (isUseAstronomicalChatzosForOtherZmanim() && synchronous) { return getHalfDayBasedZman(getChatzos(), endOfDay, 3); } else { return getShaahZmanisBasedZman(startOfDay, endOfDay, 9); @@ -845,7 +845,7 @@ public Date getSamuchLeMinchaKetana(Date startOfDay, Date endOfDay) { * be returned. See detailed explanation on top of the {@link AstronomicalCalendar} documentation. */ public Date getMinchaKetana(Date startOfDay, Date endOfDay, boolean synchronous) { - if(isUseAstronomicalChatzosForOtherZmanim() && synchronous) { + if (isUseAstronomicalChatzosForOtherZmanim() && synchronous) { return getHalfDayBasedZman(getChatzos(), endOfDay, 3.5); } else { return getShaahZmanisBasedZman(startOfDay, endOfDay, 9.5); @@ -927,7 +927,7 @@ public Date getMinchaKetana() { * will be returned. See detailed explanation on top of the {@link AstronomicalCalendar} documentation. */ public Date getPlagHamincha(Date startOfDay, Date endOfDay, boolean synchronous) { - if(isUseAstronomicalChatzosForOtherZmanim() && synchronous) { + if (isUseAstronomicalChatzosForOtherZmanim() && synchronous) { return getHalfDayBasedZman(getChatzos(), endOfDay, 4.75); } else { return getShaahZmanisBasedZman(startOfDay, endOfDay, 10.75); @@ -1083,16 +1083,13 @@ public boolean isAssurBemlacha(Date currentTime, Date tzais, boolean inIsrael) { getCalendar().get(Calendar.DAY_OF_MONTH)); jewishCalendar.setInIsrael(inIsrael); - if(jewishCalendar.hasCandleLighting() && currentTime.compareTo(getElevationAdjustedSunset()) >= 0) { //erev shabbos, YT or YT sheni and after shkiah + if (jewishCalendar.hasCandleLighting() && currentTime.compareTo(getElevationAdjustedSunset()) >= 0) { //erev shabbos, YT or YT sheni and after shkiah return true; } - - if(jewishCalendar.isAssurBemelacha() && currentTime.compareTo(tzais) <= 0) { //is shabbos or YT and it is before tzais - return true; - } - - return false; - } + + //is shabbos or YT and it is before tzais + return jewishCalendar.isAssurBemelacha() && currentTime.compareTo(tzais) <= 0; + } /** * A generic utility method for calculating any shaah zmanis (temporal hour) based zman with the @@ -1143,18 +1140,18 @@ public Date getShaahZmanisBasedZman(Date startOfDay, Date endOfDay, double hours public double getPercentOfShaahZmanisFromDegrees(double degrees, boolean sunset) { Date seaLevelSunrise = getSeaLevelSunrise(); Date seaLevelSunset = getSeaLevelSunset(); - Date twilight = null; - if(sunset) { + Date twilight; + if (sunset) { twilight = getSunsetOffsetByDegrees(GEOMETRIC_ZENITH + degrees); } else { twilight = getSunriseOffsetByDegrees(GEOMETRIC_ZENITH + degrees); } - if(seaLevelSunrise == null || seaLevelSunset == null || twilight == null) { + if (seaLevelSunrise == null || seaLevelSunset == null || twilight == null) { return Double.MIN_VALUE; } double shaahZmanis = (seaLevelSunset.getTime() - seaLevelSunrise.getTime()) / 12.0; long riseSetToTwilight; - if(sunset) { + if (sunset) { riseSetToTwilight = twilight.getTime() - seaLevelSunset.getTime(); } else { riseSetToTwilight = seaLevelSunrise.getTime() - twilight.getTime(); @@ -1197,10 +1194,10 @@ public Date getHalfDayBasedZman(Date startOfHalfDay, Date endOfHalfDay, double h return null; } long shaahZmanis = getHalfDayBasedShaahZmanis(startOfHalfDay, endOfHalfDay); - if(shaahZmanis == Long.MIN_VALUE) { //defensive, should not be needed + if (shaahZmanis == Long.MIN_VALUE) { //defensive, should not be needed return null; } - if(hours >= 0) { // forward from start a day + if (hours >= 0) { // forward from start a day return getTimeOffset(startOfHalfDay, shaahZmanis * hours); } else { // subtract from end of day return getTimeOffset(endOfHalfDay, shaahZmanis * hours); diff --git a/src/main/java/com/kosherjava/zmanim/hebrewcalendar/HebrewDateFormatter.java b/src/main/java/com/kosherjava/zmanim/hebrewcalendar/HebrewDateFormatter.java index 62f6df10..8e0d4e7f 100644 --- a/src/main/java/com/kosherjava/zmanim/hebrewcalendar/HebrewDateFormatter.java +++ b/src/main/java/com/kosherjava/zmanim/hebrewcalendar/HebrewDateFormatter.java @@ -116,13 +116,13 @@ public class HebrewDateFormatter { * שובה,שירה,הגדול, * חזון,נחמו" */ - private EnumMap hebrewParshaMap; + private final EnumMap hebrewParshaMap; /** * Default constructor sets the {@link EnumMap}s of Hebrew and default transliterated parshiyos. */ public HebrewDateFormatter() { - transliteratedParshaMap = new EnumMap(JewishCalendar.Parsha.class); + transliteratedParshaMap = new EnumMap<>(JewishCalendar.Parsha.class); transliteratedParshaMap.put(JewishCalendar.Parsha.NONE, ""); transliteratedParshaMap.put(JewishCalendar.Parsha.BERESHIS, "Bereshis"); transliteratedParshaMap.put(JewishCalendar.Parsha.NOACH, "Noach"); @@ -195,7 +195,7 @@ public HebrewDateFormatter() { transliteratedParshaMap.put(JewishCalendar.Parsha.CHAZON, "Chazon"); transliteratedParshaMap.put(JewishCalendar.Parsha.NACHAMU, "Nachamu"); - hebrewParshaMap = new EnumMap(JewishCalendar.Parsha.class); + hebrewParshaMap = new EnumMap<>(JewishCalendar.Parsha.class); hebrewParshaMap.put(JewishCalendar.Parsha.NONE, ""); hebrewParshaMap.put(JewishCalendar.Parsha.BERESHIS, "\u05D1\u05E8\u05D0\u05E9\u05D9\u05EA"); hebrewParshaMap.put(JewishCalendar.Parsha.NOACH, "\u05E0\u05D7"); @@ -292,7 +292,7 @@ public boolean isLongWeekFormat() { */ public void setLongWeekFormat(boolean longWeekFormat) { this.longWeekFormat = longWeekFormat; - if(longWeekFormat) { + if (longWeekFormat) { weekFormat = new SimpleDateFormat("EEEE"); } else { weekFormat = new SimpleDateFormat("EEE"); @@ -496,7 +496,6 @@ public String formatRoshChodesh(JewishCalendar jewishCalendar) { if (!jewishCalendar.isRoshChodesh()) { return ""; } - String formattedRoshChodesh = ""; int month = jewishCalendar.getJewishMonth(); if (jewishCalendar.getJewishDayOfMonth() == 30) { if (month < JewishCalendar.ADAR || (month == JewishCalendar.ADAR && jewishCalendar.isJewishLeapYear())) { @@ -509,7 +508,7 @@ public String formatRoshChodesh(JewishCalendar jewishCalendar) { // This method is only about formatting, so we shouldn't make any changes to the params passed in... jewishCalendar = (JewishCalendar) jewishCalendar.clone(); jewishCalendar.setJewishMonth(month); - formattedRoshChodesh = hebrewFormat ? hebrewHolidays[JewishCalendar.ROSH_CHODESH] + String formattedRoshChodesh = hebrewFormat ? hebrewHolidays[JewishCalendar.ROSH_CHODESH] : transliteratedHolidays[JewishCalendar.ROSH_CHODESH]; formattedRoshChodesh += " " + formatMonth(jewishCalendar); return formattedRoshChodesh; @@ -637,18 +636,18 @@ public void setTransliteratedMonthList(String[] transliteratedMonths) { */ public String formatDayOfWeek(JewishDate jewishDate) { if (hebrewFormat) { - if(isLongWeekFormat()) { + if (isLongWeekFormat()) { return hebrewDaysOfWeek[jewishDate.getDayOfWeek() - 1]; } else { - if(jewishDate.getDayOfWeek() == 7) { + if (jewishDate.getDayOfWeek() == 7) { return formatHebrewNumber(300); } else { return formatHebrewNumber(jewishDate.getDayOfWeek()); } } } else { - if(jewishDate.getDayOfWeek() == 7) { - if(isLongWeekFormat()) { + if (jewishDate.getDayOfWeek() == 7) { + if (isLongWeekFormat()) { return getTransliteratedShabbosDayOfWeek(); } else { return getTransliteratedShabbosDayOfWeek().substring(0,3); @@ -897,7 +896,7 @@ public String formatDafYomiBavli(Daf daf) { * @return the formatted daf. */ public String formatDafYomiYerushalmi(Daf daf) { - if(daf == null) { + if (daf == null) { if (hebrewFormat) { return Daf.getYerushalmiMasechtos()[39]; } else { @@ -990,7 +989,7 @@ public String formatHebrewNumber(int number) { int tens = number / 10; if (number % 10 == 0) { // if evenly divisible by 10 if (!singleDigitNumber) { - if(isUseFinalFormLetters()) { + if (isUseFinalFormLetters()) { sb.append(jTenEnds[tens]); // years like 5780 will end with a final form ף } else { sb.append(jTens[tens]); // years like 5780 will end with a regular פ diff --git a/src/main/java/com/kosherjava/zmanim/hebrewcalendar/JewishCalendar.java b/src/main/java/com/kosherjava/zmanim/hebrewcalendar/JewishCalendar.java index 2bc86440..229e0b39 100644 --- a/src/main/java/com/kosherjava/zmanim/hebrewcalendar/JewishCalendar.java +++ b/src/main/java/com/kosherjava/zmanim/hebrewcalendar/JewishCalendar.java @@ -177,7 +177,7 @@ public class JewishCalendar extends JewishDate { * @see #getSpecialShabbos() * @see #getParshah() */ - public static enum Parsha { + public enum Parsha { /**NONE A week without any parsha such as Shabbos Chol Hamoed */NONE, /**BERESHIS*/BERESHIS, /**NOACH*/NOACH, /**LECH_LECHA*/LECH_LECHA, /**VAYERA*/VAYERA, /**CHAYEI_SARA*/CHAYEI_SARA, /**TOLDOS*/TOLDOS, /**VAYETZEI*/VAYETZEI, /**VAYISHLACH*/VAYISHLACH, /**VAYESHEV*/VAYESHEV, /**MIKETZ*/MIKETZ, /**VAYIGASH*/VAYIGASH, /**VAYECHI*/VAYECHI, @@ -387,11 +387,9 @@ public boolean isBirkasHachamah() { * Rosh Hashana as 1, we have to add 1 day for a total of 171. To this add a day since the tekufah is on a Tuesday * night, and we push off the bracha to Wednesday morning resulting in the 172 used in the calculation. */ - if (elapsedDays % (28 * 365.25) == 172) { // 28 years of 365.25 days + the offset from molad tohu mentioned above - return true; - } - return false; - } + // 28 years of 365.25 days + the offset from molad tohu mentioned above + return elapsedDays % (28 * 365.25) == 172; + } /** * Return the type of year for parsha calculations. The algorithm follows the @@ -564,28 +562,28 @@ public Parsha getSpecialShabbos() { } } if (getJewishMonth() == NISSAN) { - if(getJewishDayOfMonth() == 1) { + if (getJewishDayOfMonth() == 1) { return Parsha.HACHODESH; } - if(getJewishDayOfMonth() >= 8 && getJewishDayOfMonth() <= 14) { + if (getJewishDayOfMonth() >= 8 && getJewishDayOfMonth() <= 14) { return Parsha.HAGADOL; } } if (getJewishMonth() == AV) { - if(getJewishDayOfMonth() >= 4 && getJewishDayOfMonth() <= 9) { + if (getJewishDayOfMonth() >= 4 && getJewishDayOfMonth() <= 9) { return Parsha.CHAZON; } - if(getJewishDayOfMonth() >= 10 && getJewishDayOfMonth() <= 16) { + if (getJewishDayOfMonth() >= 10 && getJewishDayOfMonth() <= 16) { return Parsha.NACHAMU; } } if (getJewishMonth() == TISHREI) { - if(getJewishDayOfMonth() >= 3 && getJewishDayOfMonth() <= 8) { + if (getJewishDayOfMonth() >= 3 && getJewishDayOfMonth() <= 8) { return Parsha.SHUVA; } } - if(getParshah() == Parsha.BESHALACH) { + if (getParshah() == Parsha.BESHALACH) { return Parsha.SHIRA; } } @@ -617,11 +615,10 @@ public int getYomTovIndex() { || (!inIsrael && (day == 16 || day == 22))) { return PESACH; } - if (day >= 17 && day <= 20 - || (day == 16 && inIsrael)) { + if (day >= 17 && day <= 20 || day == 16) { return CHOL_HAMOED_PESACH; } - if ((day == 22 && inIsrael) || (day == 23 && !inIsrael)) { + if (day == 22 || day == 23 && !inIsrael) { return ISRU_CHAG; } if (isUseModernHolidays() @@ -661,7 +658,7 @@ public int getYomTovIndex() { if (day == 6 || (day == 7 && !inIsrael)) { return SHAVUOS; } - if ((day == 7 && inIsrael) || (day == 8 && !inIsrael)) { + if (day == 7 || day == 8 && !inIsrael) { return ISRU_CHAG; } break; @@ -707,7 +704,7 @@ public int getYomTovIndex() { if (day == 15 || (day == 16 && !inIsrael)) { return SUCCOS; } - if (day >= 17 && day <= 20 || (day == 16 && inIsrael)) { + if (day >= 17 && day <= 20 || day == 16) { return CHOL_HAMOED_SUCCOS; } if (day == 21) { @@ -719,7 +716,7 @@ public int getYomTovIndex() { if (day == 23 && !inIsrael) { return SIMCHAS_TORAH; } - if ((day == 23 && inIsrael) || (day == 24 && !inIsrael)) { + if (day == 23 || day == 24 && !inIsrael) { return ISRU_CHAG; } break; @@ -1061,19 +1058,16 @@ public boolean isYomKippurKatan() { int dayOfWeek = getDayOfWeek(); int month = getJewishMonth(); int day = getJewishDayOfMonth(); - if(month == JewishDate.ELUL || month == JewishDate.TISHREI || month == JewishDate.KISLEV || month == JewishDate.NISSAN) { + if (month == JewishDate.ELUL || month == JewishDate.TISHREI || month == JewishDate.KISLEV || month == JewishDate.NISSAN) { return false; } - if(day == 29 && dayOfWeek != Calendar.FRIDAY && dayOfWeek != Calendar.SATURDAY) { + if (day == 29 && dayOfWeek != Calendar.FRIDAY && dayOfWeek != Calendar.SATURDAY) { return true; } - - if((day == 27 || day == 28) && dayOfWeek == Calendar.THURSDAY ) { - return true; - } - return false; - } + + return (day == 27 || day == 28) && dayOfWeek == Calendar.THURSDAY; + } /** * The Monday, Thursday and Monday after the first Shabbos after {@link #isRoshChodesh() Rosh Chodesh} @@ -1090,10 +1084,8 @@ public boolean isBeHaB() { int day = getJewishDayOfMonth(); if (month == JewishDate.CHESHVAN || month == JewishDate.IYAR) { - if((dayOfWeek == Calendar.MONDAY && day > 4 && day < 18) - || (dayOfWeek == Calendar.THURSDAY && day > 7 && day < 14)) { - return true; - } + return (dayOfWeek == Calendar.MONDAY && day > 4 && day < 18) + || (dayOfWeek == Calendar.THURSDAY && day > 7 && day < 14); } return false; } @@ -1163,7 +1155,7 @@ public boolean isChanukah() { * @see #setIsMukafChoma(boolean) */ public boolean isPurim() { - if(isMukafChoma) { + if (isMukafChoma) { return getYomTovIndex() == SHUSHAN_PURIM; } else { return getYomTovIndex() == PURIM; @@ -1427,9 +1419,7 @@ public int getTekufasTishreiElapsedDays() { public boolean isVeseinTalUmatarStartDate() { if (inIsrael) { // The 7th Cheshvan can't occur on Shabbos, so always return true for 7 Cheshvan - if (getJewishMonth() == CHESHVAN && getJewishDayOfMonth() == 7) { - return true; - } + return getJewishMonth() == CHESHVAN && getJewishDayOfMonth() == 7; } else { if (getDayOfWeek() == Calendar.SATURDAY) { //Not recited on Friday night return false; @@ -1440,8 +1430,7 @@ public boolean isVeseinTalUmatarStartDate() { return getTekufasTishreiElapsedDays() == 47; } } - return false; // keep the compiler happy - } + } /** * Returns true if tonight is the first night to start reciting Vesein Tal Umatar Livracha ( @@ -1464,9 +1453,7 @@ public boolean isVeseinTalUmatarStartDate() { public boolean isVeseinTalUmatarStartingTonight() { if (inIsrael) { // The 7th Cheshvan can't occur on Shabbos, so always return true for 6 Cheshvan - if (getJewishMonth() == CHESHVAN && getJewishDayOfMonth() == 6) { - return true; - } + return getJewishMonth() == CHESHVAN && getJewishDayOfMonth() == 6; } else { if (getDayOfWeek() == Calendar.FRIDAY) { //Not recited on Friday night return false; @@ -1477,8 +1464,7 @@ public boolean isVeseinTalUmatarStartingTonight() { return getTekufasTishreiElapsedDays() == 46; } } - return false; - } + } /** * Returns if Vesein Tal Umatar Livracha (Sheailas Geshamim) is recited. This will return diff --git a/src/main/java/com/kosherjava/zmanim/hebrewcalendar/JewishDate.java b/src/main/java/com/kosherjava/zmanim/hebrewcalendar/JewishDate.java index 3286500e..e38af3e8 100644 --- a/src/main/java/com/kosherjava/zmanim/hebrewcalendar/JewishDate.java +++ b/src/main/java/com/kosherjava/zmanim/hebrewcalendar/JewishDate.java @@ -1306,7 +1306,7 @@ public void forward(int field, int amount) { } } else if (field == Calendar.MONTH) { forwardJewishMonth(amount); - } else if (field == Calendar.YEAR) { + } else { setJewishYear(getJewishYear() + amount); } } @@ -1324,7 +1324,7 @@ private void forwardJewishMonth(int amount) { throw new IllegalArgumentException("the amount of months to forward has to be greater than zero."); } for (int i = 0; i < amount; i++) { - if(getJewishMonth() == ELUL) { + if (getJewishMonth() == ELUL) { setJewishMonth(TISHREI); setJewishYear(getJewishYear() + 1); } else if ((! isJewishLeapYear() && getJewishMonth() == ADAR) @@ -1570,8 +1570,10 @@ public Object clone() { } catch (CloneNotSupportedException cnse) { // Required by the compiler. Should never be reached since we implement clone() } - clone.setInternalGregorianDate(gregorianYear, gregorianMonth, gregorianDayOfMonth); - return clone; + if (clone != null) { + clone.setInternalGregorianDate(gregorianYear, gregorianMonth, gregorianDayOfMonth); + } + return clone; } /** diff --git a/src/main/java/com/kosherjava/zmanim/hebrewcalendar/TefilaRules.java b/src/main/java/com/kosherjava/zmanim/hebrewcalendar/TefilaRules.java index fbe8473b..89736b2f 100644 --- a/src/main/java/com/kosherjava/zmanim/hebrewcalendar/TefilaRules.java +++ b/src/main/java/com/kosherjava/zmanim/hebrewcalendar/TefilaRules.java @@ -204,8 +204,7 @@ public boolean isTachanunRecitedShacharis(JewishCalendar jewishCalendar) { * @see #isTachanunRecitedShacharis(JewishCalendar) */ public boolean isTachanunRecitedMincha(JewishCalendar jewishCalendar) { - JewishCalendar tomorrow = new JewishCalendar(); - tomorrow = (JewishCalendar) jewishCalendar.clone(); + JewishCalendar tomorrow = (JewishCalendar) jewishCalendar.clone(); tomorrow.forward(Calendar.DATE, 1); return tachanunRecitedMinchaAllYear @@ -238,21 +237,18 @@ && isTachanunRecitedShacharis(jewishCalendar) public boolean isVeseinTalUmatarStartDate(JewishCalendar jewishCalendar) { if (jewishCalendar.getInIsrael()) { // The 7th Cheshvan can't occur on Shabbos, so always return true for 7 Cheshvan - if (jewishCalendar.getJewishMonth() == JewishDate.CHESHVAN && jewishCalendar.getJewishDayOfMonth() == 7) { - return true; - } + return jewishCalendar.getJewishMonth() == JewishDate.CHESHVAN && jewishCalendar.getJewishDayOfMonth() == 7; } else { if (jewishCalendar.getDayOfWeek() == Calendar.SATURDAY) { //Not recited on Friday night return false; } - if(jewishCalendar.getDayOfWeek() == Calendar.SUNDAY) { // When starting on Sunday, it can be the start date or delayed from Shabbos + if (jewishCalendar.getDayOfWeek() == Calendar.SUNDAY) { // When starting on Sunday, it can be the start date or delayed from Shabbos return jewishCalendar.getTekufasTishreiElapsedDays() == 48 || jewishCalendar.getTekufasTishreiElapsedDays() == 47; } else { return jewishCalendar.getTekufasTishreiElapsedDays() == 47; } } - return false; // keep the compiler happy - } + } /** * Returns true if tonight is the first night to start reciting Vesein Tal Umatar Livracha ( @@ -274,21 +270,18 @@ public boolean isVeseinTalUmatarStartDate(JewishCalendar jewishCalendar) { public boolean isVeseinTalUmatarStartingTonight(JewishCalendar jewishCalendar) { if (jewishCalendar.getInIsrael()) { // The 7th Cheshvan can't occur on Shabbos, so always return true for 6 Cheshvan - if (jewishCalendar.getJewishMonth() == JewishDate.CHESHVAN && jewishCalendar.getJewishDayOfMonth() == 6) { - return true; - } + return jewishCalendar.getJewishMonth() == JewishDate.CHESHVAN && jewishCalendar.getJewishDayOfMonth() == 6; } else { if (jewishCalendar.getDayOfWeek() == Calendar.FRIDAY) { //Not recited on Friday night return false; } - if(jewishCalendar.getDayOfWeek() == Calendar.SATURDAY) { // When starting on motzai Shabbos, it can be the start date or delayed from Friday night + if (jewishCalendar.getDayOfWeek() == Calendar.SATURDAY) { // When starting on motzai Shabbos, it can be the start date or delayed from Friday night return jewishCalendar.getTekufasTishreiElapsedDays() == 47 || jewishCalendar.getTekufasTishreiElapsedDays() == 46; } else { return jewishCalendar.getTekufasTishreiElapsedDays() == 46; } } - return false; - } + } /** * Returns if Vesein Tal Umatar Livracha (Sheailas Geshamim) is recited. This will return @@ -324,7 +317,7 @@ public boolean isVeseinTalUmatarRecited(JewishCalendar jewishCalendar) { * @see #isVeseinTalUmatarRecited(JewishCalendar) */ public boolean isVeseinBerachaRecited(JewishCalendar jewishCalendar) { - return ! isVeseinTalUmatarRecited(jewishCalendar); + return !isVeseinTalUmatarRecited(jewishCalendar); } /** @@ -396,20 +389,20 @@ public boolean isHallelRecited(JewishCalendar jewishCalendar) { int holidayIndex = jewishCalendar.getYomTovIndex(); boolean inIsrael = jewishCalendar.getInIsrael(); - if(jewishCalendar.isRoshChodesh()) { //RH returns false for RC + if (jewishCalendar.isRoshChodesh()) { //RH returns false for RC return true; } - if(jewishCalendar.isChanukah()) { + if (jewishCalendar.isChanukah()) { return true; } switch (month) { case JewishDate.NISSAN: - if(day >= 15 && ((inIsrael && day <= 21) || (!inIsrael && day <= 22))){ + if (day >= 15 && ((inIsrael && day <= 21) || (!inIsrael && day <= 22))){ return true; } break; case JewishDate.IYAR: // modern holidays - if(jewishCalendar.isUseModernHolidays() && (holidayIndex == JewishCalendar.YOM_HAATZMAUT + if (jewishCalendar.isUseModernHolidays() && (holidayIndex == JewishCalendar.YOM_HAATZMAUT || holidayIndex == JewishCalendar.YOM_YERUSHALAYIM)){ return true; } @@ -439,10 +432,10 @@ public boolean isHallelShalemRecited(JewishCalendar jewishCalendar) { int day = jewishCalendar.getJewishDayOfMonth(); int month = jewishCalendar.getJewishMonth(); boolean inIsrael = jewishCalendar.getInIsrael(); - if(isHallelRecited(jewishCalendar)) { + if (isHallelRecited(jewishCalendar)) { return (!jewishCalendar.isRoshChodesh() || jewishCalendar.isChanukah()) && (month != JewishDate.NISSAN || ((!inIsrael || day <= 15) && (inIsrael || day <= 16))); - } + } return false; } @@ -488,16 +481,17 @@ public boolean isYaalehVeyavoRecited(JewishCalendar jewishCalendar) { * */ public boolean isMizmorLesodaRecited(JewishCalendar jewishCalendar) { - if(jewishCalendar.isAssurBemelacha()) { + if (jewishCalendar.isAssurBemelacha()) { return false; } int holidayIndex = jewishCalendar.getYomTovIndex(); - return isMizmorLesodaRecitedErevYomKippurAndPesach() + return isMizmorLesodaRecitedErevYomKippurAndPesach() || (holidayIndex != JewishCalendar.EREV_YOM_KIPPUR && holidayIndex != JewishCalendar.EREV_PESACH && !jewishCalendar.isCholHamoedPesach()); } + } /** * Is tachanun set to be recited during the week of Purim, from the 11th through the 17th of {@link diff --git a/src/main/java/com/kosherjava/zmanim/hebrewcalendar/YerushalmiYomiCalculator.java b/src/main/java/com/kosherjava/zmanim/hebrewcalendar/YerushalmiYomiCalculator.java index a1aaf21b..19e4031f 100644 --- a/src/main/java/com/kosherjava/zmanim/hebrewcalendar/YerushalmiYomiCalculator.java +++ b/src/main/java/com/kosherjava/zmanim/hebrewcalendar/YerushalmiYomiCalculator.java @@ -95,15 +95,15 @@ public static Daf getDafYomiYerushalmi(JewishCalendar calendar) { int total = dafNo - specialDays; // Finally find the daf. - for (int j = 0; j < BLATT_PER_MASECHTA.length; j++) { - - if (total < BLATT_PER_MASECHTA[j]) { - dafYomi = new Daf(masechta, total + 1); - break; - } - total -= BLATT_PER_MASECHTA[j]; - masechta++; - } + for (int i : BLATT_PER_MASECHTA) { + + if (total < i) { + dafYomi = new Daf(masechta, total + 1); + break; + } + total -= i; + masechta++; + } return dafYomi; } diff --git a/src/main/java/com/kosherjava/zmanim/hebrewcalendar/YomiCalculator.java b/src/main/java/com/kosherjava/zmanim/hebrewcalendar/YomiCalculator.java index cedfabef..108a0a3c 100644 --- a/src/main/java/com/kosherjava/zmanim/hebrewcalendar/YomiCalculator.java +++ b/src/main/java/com/kosherjava/zmanim/hebrewcalendar/YomiCalculator.java @@ -80,8 +80,8 @@ public static Daf getDafYomiBavli(JewishCalendar jewishCalendar) { Daf dafYomi = null; int julianDay = getJulianDay(calendar); - int cycleNo = 0; - int dafNo = 0; + int cycleNo; + int dafNo; if (calendar.before(dafYomiStartDay)) { // TODO: should we return a null or throw an IllegalArgumentException? throw new IllegalArgumentException(calendar + " is prior to organized Daf Yomi Bavli cycles that started on " @@ -97,32 +97,30 @@ public static Daf getDafYomiBavli(JewishCalendar jewishCalendar) { int total = 0; int masechta = -1; - int blatt = 0; + int blatt; // Fix Shekalim for old cycles. if (cycleNo <= 7) { blattPerMasechta[4] = 13; - } else { - blattPerMasechta[4] = 22; // correct any change that may have been changed from a prior calculation } // Finally find the daf. - for (int j = 0; j < blattPerMasechta.length; j++) { - masechta++; - total = total + blattPerMasechta[j] - 1; - if (dafNo < total) { - blatt = 1 + blattPerMasechta[j] - (total - dafNo); - // Fiddle with the weird ones near the end. - if (masechta == 36) { - blatt += 21; - } else if (masechta == 37) { - blatt += 24; - } else if (masechta == 38) { - blatt += 32; - } - dafYomi = new Daf(masechta, blatt); - break; - } - } + for (int i : blattPerMasechta) { + masechta++; + total = total + i - 1; + if (dafNo < total) { + blatt = 1 + i - (total - dafNo); + // Fiddle with the weird ones near the end. + if (masechta == 36) { + blatt += 21; + } else if (masechta == 37) { + blatt += 24; + } else if (masechta == 38) { + blatt += 32; + } + dafYomi = new Daf(masechta, blatt); + break; + } + } return dafYomi; } diff --git a/src/main/java/com/kosherjava/zmanim/util/GeoLocation.java b/src/main/java/com/kosherjava/zmanim/util/GeoLocation.java index 37e39e49..1bd60477 100644 --- a/src/main/java/com/kosherjava/zmanim/util/GeoLocation.java +++ b/src/main/java/com/kosherjava/zmanim/util/GeoLocation.java @@ -15,6 +15,7 @@ */ package com.kosherjava.zmanim.util; +import java.util.Objects; import java.util.TimeZone; /** @@ -549,20 +550,18 @@ public double getRhumbLineDistance(GeoLocation location) { * @return The XML formatted String. */ public String toXML() { - StringBuilder sb = new StringBuilder(); - sb.append("\n"); - sb.append("\t").append(getLocationName()).append("\n"); - sb.append("\t").append(getLatitude()).append("\n"); - sb.append("\t").append(getLongitude()).append("\n"); - sb.append("\t").append(getElevation()).append(" Meters").append("\n"); - sb.append("\t").append(getTimeZone().getID()).append("\n"); - sb.append("\t").append(getTimeZone().getDisplayName()).append("\n"); - sb.append("\t").append(getTimeZone().getRawOffset() / HOUR_MILLIS) - .append("\n"); - sb.append("\t").append(getTimeZone().getDSTSavings() / HOUR_MILLIS) - .append("\n"); - sb.append(""); - return sb.toString(); + return "\n" + + "\t" + getLocationName() + "\n" + + "\t" + getLatitude() + "\n" + + "\t" + getLongitude() + "\n" + + "\t" + getElevation() + " Meters" + "\n" + + "\t" + getTimeZone().getID() + "\n" + + "\t" + getTimeZone().getDisplayName() + "\n" + + "\t" + getTimeZone().getRawOffset() / HOUR_MILLIS + + "\n" + + "\t" + getTimeZone().getDSTSavings() / HOUR_MILLIS + + "\n" + + ""; } /** @@ -577,8 +576,8 @@ public boolean equals(Object object) { return Double.doubleToLongBits(this.latitude) == Double.doubleToLongBits(geo.latitude) && Double.doubleToLongBits(this.longitude) == Double.doubleToLongBits(geo.longitude) && this.elevation == geo.elevation - && (this.locationName == null ? geo.locationName == null : this.locationName.equals(geo.locationName)) - && (this.timeZone == null ? geo.timeZone == null : this.timeZone.equals(geo.timeZone)); + && (Objects.equals(this.locationName, geo.locationName)) + && (Objects.equals(this.timeZone, geo.timeZone)); } /** @@ -606,17 +605,15 @@ public int hashCode() { * @see java.lang.Object#toString() */ public String toString() { - StringBuilder sb = new StringBuilder(); - sb.append("\nLocation Name:\t\t\t").append(getLocationName()); - sb.append("\nLatitude:\t\t\t").append(getLatitude()).append("\u00B0"); - sb.append("\nLongitude:\t\t\t").append(getLongitude()).append("\u00B0"); - sb.append("\nElevation:\t\t\t").append(getElevation()).append(" Meters"); - sb.append("\nTimezone ID:\t\t\t").append(getTimeZone().getID()); - sb.append("\nTimezone Display Name:\t\t").append(getTimeZone().getDisplayName()) - .append(" (").append(getTimeZone().getDisplayName(false, TimeZone.SHORT)).append(")"); - sb.append("\nTimezone GMT Offset:\t\t").append(getTimeZone().getRawOffset() / HOUR_MILLIS); - sb.append("\nTimezone DST Offset:\t\t").append(getTimeZone().getDSTSavings() / HOUR_MILLIS); - return sb.toString(); + return "\nLocation Name:\t\t\t" + getLocationName() + + "\nLatitude:\t\t\t" + getLatitude() + "\u00B0" + + "\nLongitude:\t\t\t" + getLongitude() + "\u00B0" + + "\nElevation:\t\t\t" + getElevation() + " Meters" + + "\nTimezone ID:\t\t\t" + getTimeZone().getID() + + "\nTimezone Display Name:\t\t" + getTimeZone().getDisplayName() + + " (" + getTimeZone().getDisplayName(false, TimeZone.SHORT) + ")" + + "\nTimezone GMT Offset:\t\t" + getTimeZone().getRawOffset() / HOUR_MILLIS + + "\nTimezone DST Offset:\t\t" + getTimeZone().getDSTSavings() / HOUR_MILLIS; } /** @@ -637,8 +634,10 @@ public Object clone() { } catch (CloneNotSupportedException cnse) { //Required by the compiler. Should never be reached since we implement clone() } - clone.timeZone = (TimeZone) getTimeZone().clone(); - clone.locationName = getLocationName(); + if (clone != null) { + clone.timeZone = (TimeZone) getTimeZone().clone(); + clone.locationName = getLocationName(); + } return clone; } } diff --git a/src/main/java/com/kosherjava/zmanim/util/NOAACalculator.java b/src/main/java/com/kosherjava/zmanim/util/NOAACalculator.java index 9fcef686..799c3a6e 100644 --- a/src/main/java/com/kosherjava/zmanim/util/NOAACalculator.java +++ b/src/main/java/com/kosherjava/zmanim/util/NOAACalculator.java @@ -243,8 +243,7 @@ private static double getSunApparentLongitude(double julianCenturies) { double sunTrueLongitude = getSunTrueLongitude(julianCenturies); double omega = 125.04 - 1934.136 * julianCenturies; - double lambda = sunTrueLongitude - 0.00569 - 0.00478 * Math.sin(Math.toRadians(omega)); - return lambda; // in degrees + return sunTrueLongitude - 0.00569 - 0.00478 * Math.sin(Math.toRadians(omega)); // in degrees } /** @@ -291,8 +290,7 @@ private static double getSunDeclination(double julianCenturies) { double lambda = getSunApparentLongitude(julianCenturies); double sint = Math.sin(Math.toRadians(obliquityCorrection)) * Math.sin(Math.toRadians(lambda)); - double theta = Math.toDegrees(Math.asin(sint)); - return theta; // in degrees + return Math.toDegrees(Math.asin(sint)); // in degrees } /** @@ -385,7 +383,7 @@ public static double getSolarElevation(Calendar cal, double lat, double lon) { double julianDay = getJulianDay(cal); double julianCenturies = getJulianCenturiesFromJulianDay(julianDay); - Double eot = getEquationOfTime(julianCenturies); + double eot = getEquationOfTime(julianCenturies); double longitude = (cal.get(Calendar.HOUR_OF_DAY) + 12.0) + (cal.get(Calendar.MINUTE) + eot + cal.get(Calendar.SECOND) / 60.0) / 60.0; @@ -418,7 +416,7 @@ public static double getSolarAzimuth(Calendar cal, double lat, double lon) { double julianDay = getJulianDay(cal); double julianCenturies = getJulianCenturiesFromJulianDay(julianDay); - Double eot = getEquationOfTime(julianCenturies); + double eot = getEquationOfTime(julianCenturies); double longitude = (cal.get(Calendar.HOUR_OF_DAY) + 12.0) + (cal.get(Calendar.MINUTE) + eot + cal.get(Calendar.SECOND) / 60.0) / 60.0; diff --git a/src/main/java/com/kosherjava/zmanim/util/SunTimesCalculator.java b/src/main/java/com/kosherjava/zmanim/util/SunTimesCalculator.java index 42c864fe..cc6110bc 100644 --- a/src/main/java/com/kosherjava/zmanim/util/SunTimesCalculator.java +++ b/src/main/java/com/kosherjava/zmanim/util/SunTimesCalculator.java @@ -42,22 +42,18 @@ public String getCalculatorName() { * @see com.kosherjava.zmanim.util.AstronomicalCalculator#getUTCSunrise(Calendar, GeoLocation, double, boolean) */ public double getUTCSunrise(Calendar calendar, GeoLocation geoLocation, double zenith, boolean adjustForElevation) { - double doubleTime = Double.NaN; double elevation = adjustForElevation ? geoLocation.getElevation() : 0; double adjustedZenith = adjustZenith(zenith, elevation); - doubleTime = getTimeUTC(calendar, geoLocation, adjustedZenith, true); - return doubleTime; + return getTimeUTC(calendar, geoLocation, adjustedZenith, true); } /** * @see com.kosherjava.zmanim.util.AstronomicalCalculator#getUTCSunset(Calendar, GeoLocation, double, boolean) */ public double getUTCSunset(Calendar calendar, GeoLocation geoLocation, double zenith, boolean adjustForElevation) { - double doubleTime = Double.NaN; double elevation = adjustForElevation ? geoLocation.getElevation() : 0; double adjustedZenith = adjustZenith(zenith, elevation); - doubleTime = getTimeUTC(calendar, geoLocation, adjustedZenith, false); - return doubleTime; + return getTimeUTC(calendar, geoLocation, adjustedZenith, false); } /** @@ -233,7 +229,7 @@ private static double getTimeUTC(Calendar calendar, GeoLocation geoLocation, dou double sunRightAscensionHours = getSunRightAscensionHours(sunTrueLong); double cosLocalHourAngle = getCosLocalHourAngle(sunTrueLong, geoLocation.getLatitude(), zenith); - double localHourAngle = 0; + double localHourAngle; if (isSunrise) { localHourAngle = 360.0 - acosDeg(cosLocalHourAngle); } else { // sunset @@ -274,10 +270,10 @@ public double getUTCNoon(Calendar calendar, GeoLocation geoLocation) { double sunrise = getUTCSunrise(calendar, geoLocation, 90, false); double sunset = getUTCSunset(calendar, geoLocation, 90, false); double noon = sunrise + ((sunset - sunrise) / 2); - if(noon < 0) { + if (noon < 0) { noon += 12; } - if(noon < sunrise) { + if (noon < sunrise) { noon -= 12; } return noon; diff --git a/src/main/java/com/kosherjava/zmanim/util/Time.java b/src/main/java/com/kosherjava/zmanim/util/Time.java index 12575619..c3323449 100644 --- a/src/main/java/com/kosherjava/zmanim/util/Time.java +++ b/src/main/java/com/kosherjava/zmanim/util/Time.java @@ -37,22 +37,22 @@ public class Time { /** * @see #getHours() */ - private int hours = 0; + private int hours; /** * @see #getMinutes() */ - private int minutes = 0; + private int minutes; /** * @see #getSeconds() */ - private int seconds = 0; + private int seconds; /** * @see #getMilliseconds() */ - private int milliseconds = 0; + private int milliseconds; /** * @see #isNegative()