Atlanta Custom Software Development 

 
   Search        Code/Page
 

User Login
Email

Password

 

Forgot the Password?
Services
» Web Development
» Maintenance
» Data Integration/BI
» Information Management
Programming
  Database
Automation
OS/Networking
Graphics
Links
Tools
» Regular Expr Tester
» Free Tools

GetRoshHashanah - Get the date of Rosh Hashanah (Jewish calendar)

Total Hit ( 2800)

Rate this article:     Poor     Excellent 

 Submit Your Question/Comment about this article

Rating


 



Click here to copy the following block
' Returns the date that Rosh Hashanah begins
' for the requested year. It is important to note that
' Rosh Hashanah is based on the Lunar cycle so the Holiday
' actually begins at sunset of the day before the date
' returned by this function.

' Note: Many dates in the Jewish calendar are dependent on the date
'of Rosh Hashanah just as Good Friday, Lent, and other dates
' are dependent on Easter. 

Public Function GetRoshHashanah(iYear As Integer) As Date
  
  Dim dDate As Single, iDate As Integer, iDayOfWeek As Integer
  Dim JY As Integer, JtoG As Integer, iMonth As Integer
  
  ' Conversion factors
  Const F1 As Single = 765433 / 492480
  Const F2 As Single = 23269 / 25920
  Const F3 As Single = 765433 / 492480
  
  JY = (12 * ((iYear Mod 19) + 1)) Mod 19
  
  ' Correct from Julian date to Gregorian date
  JtoG = iYear \ 100 - iYear \ 400 - 2
  
  dDate = JtoG + F1 * JY + (iYear Mod 4) / 4 - (313 * CLng(iYear) + 89081) / _
    98496
  
  ' Get the integer portion of the date
  iDate = Int(dDate)
  ' Get the fractional portion of the date
  dDate = dDate - iDate
  
  If iDate > 30 Then
    iDate = iDate - 30
    iMonth = 10
  ElseIf iDate < 1 Then
    iDate = iDate + 31
    iMonth = 8
  Else
    iMonth = 9
  End If
  
  iDayOfWeek = Weekday(DateSerial(iYear, iMonth, iDate))
  
  ' Postponement Rules
  ' If day of week is Sunday, Wednesday, or Friday
  If iDayOfWeek = 1 Or iDayOfWeek = 4 Or iDayOfWeek = 6 Then
    iDate = iDate + 1
  ' If day is Monday
  ElseIf iDayOfWeek = 2 And dDate > F1 And JY > 11 Then
    iDate = iDate + 1
  ' If day is Tuesday we may need to add two days
  ElseIf iDayOfWeek = 3 And dDate >= F2 And JY > 6 Then
    iDate = iDate + 2
  End If
  
  If iDate > 30 Then
    iDate = iDate - 30
    iMonth = 10
  ElseIf iDate < 1 Then
    iDate = iDate + 31
    iMonth = 8
  Else
    iMonth = 9
  End If
  
  GetRoshHashanah = DateSerial(iYear, iMonth, iDate)
  
End Function


Submitted By : Nayan Patel  (Member Since : 5/26/2004 12:23:06 PM)

Job Description : He is the moderator of this site and currently working as an independent consultant. He works with VB.net/ASP.net, SQL Server and other MS technologies. He is MCSD.net, MCDBA and MCSE. In his free time he likes to watch funny movies and doing oil painting.
View all (893) submissions by this author  (Birth Date : 7/14/1981 )


Home   |  Comment   |  Contact Us   |  Privacy Policy   |  Terms & Conditions   |  BlogsZappySys

© 2008 BinaryWorld LLC. All rights reserved.