| author | miham | 
| Mon, 15 Oct 2007 17:58:42 +0000 | |
| changeset 8228 | c12ebf52053f | 
| parent 6574 | e1d1a12faaf7 | 
| permissions | -rw-r--r-- | 
| 4261 
2ec8f5a9747b
(svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
 rubidium parents: diff
changeset | 1 | /* $Id$ */ | 
| 
2ec8f5a9747b
(svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
 rubidium parents: diff
changeset | 2 | |
| 6451 
7baba06b4b85
(svn r8862) -Cleanup: doxygen changes, again. Mostly @files missing tags and a few comments style.
 belugas parents: 
5726diff
changeset | 3 | /** @file date.h */ | 
| 
7baba06b4b85
(svn r8862) -Cleanup: doxygen changes, again. Mostly @files missing tags and a few comments style.
 belugas parents: 
5726diff
changeset | 4 | |
| 4666 
850b5b6e4bac
(svn r6560) - Codechange: Minor fix; add missing #include guards and comments, and correct svn properties on bmp.[ch]
 peter1138 parents: 
4329diff
changeset | 5 | #ifndef DATE_H | 
| 
850b5b6e4bac
(svn r6560) - Codechange: Minor fix; add missing #include guards and comments, and correct svn properties on bmp.[ch]
 peter1138 parents: 
4329diff
changeset | 6 | #define DATE_H | 
| 
850b5b6e4bac
(svn r6560) - Codechange: Minor fix; add missing #include guards and comments, and correct svn properties on bmp.[ch]
 peter1138 parents: 
4329diff
changeset | 7 | |
| 5720 
cc0ceeafaa55
(svn r7751) -Codechange: move network_* to a new network map. Furthermore move the low level network functions to network/core, so they can be reused by the masterserver and website-serverlist-updater.
 rubidium parents: 
4666diff
changeset | 8 | #include "openttd.h" | 
| 
cc0ceeafaa55
(svn r7751) -Codechange: move network_* to a new network map. Furthermore move the low level network functions to network/core, so they can be reused by the masterserver and website-serverlist-updater.
 rubidium parents: 
4666diff
changeset | 9 | |
| 4261 
2ec8f5a9747b
(svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
 rubidium parents: diff
changeset | 10 | /** | 
| 
2ec8f5a9747b
(svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
 rubidium parents: diff
changeset | 11 | * 1 day is 74 ticks; _date_fract used to be uint16 and incremented by 885. On | 
| 
2ec8f5a9747b
(svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
 rubidium parents: diff
changeset | 12 | * an overflow the new day begun and 65535 / 885 = 74. | 
| 
2ec8f5a9747b
(svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
 rubidium parents: diff
changeset | 13 | * 1 tick is approximately 30 ms. | 
| 
2ec8f5a9747b
(svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
 rubidium parents: diff
changeset | 14 | * 1 day is thus about 2 seconds (74 * 30 = 2220) on a machine that can run OpenTTD normally | 
| 
2ec8f5a9747b
(svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
 rubidium parents: diff
changeset | 15 | */ | 
| 
2ec8f5a9747b
(svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
 rubidium parents: diff
changeset | 16 | #define DAY_TICKS 74 | 
| 
2ec8f5a9747b
(svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
 rubidium parents: diff
changeset | 17 | |
| 4322 
0bee6d9bc452
(svn r5975) -Cleanup: use ORIGINAL_BASE_YEAR & ORIGINAL_MAX_YEAR where the functions really depend on the original date format.
 rubidium parents: 
4295diff
changeset | 18 | /* | 
| 
0bee6d9bc452
(svn r5975) -Cleanup: use ORIGINAL_BASE_YEAR & ORIGINAL_MAX_YEAR where the functions really depend on the original date format.
 rubidium parents: 
4295diff
changeset | 19 | * ORIGINAL_BASE_YEAR, ORIGINAL_MAX_YEAR and DAYS_TILL_ORIGINAL_BASE_YEAR are | 
| 
0bee6d9bc452
(svn r5975) -Cleanup: use ORIGINAL_BASE_YEAR & ORIGINAL_MAX_YEAR where the functions really depend on the original date format.
 rubidium parents: 
4295diff
changeset | 20 | * primarily used for loading newgrf and savegame data and returning some | 
| 
0bee6d9bc452
(svn r5975) -Cleanup: use ORIGINAL_BASE_YEAR & ORIGINAL_MAX_YEAR where the functions really depend on the original date format.
 rubidium parents: 
4295diff
changeset | 21 | * newgrf (callback) functions that were in the original (TTD) inherited | 
| 
0bee6d9bc452
(svn r5975) -Cleanup: use ORIGINAL_BASE_YEAR & ORIGINAL_MAX_YEAR where the functions really depend on the original date format.
 rubidium parents: 
4295diff
changeset | 22 | * format, where '_date == 0' meant that it was 1920-01-01. | 
| 
0bee6d9bc452
(svn r5975) -Cleanup: use ORIGINAL_BASE_YEAR & ORIGINAL_MAX_YEAR where the functions really depend on the original date format.
 rubidium parents: 
4295diff
changeset | 23 | */ | 
| 
0bee6d9bc452
(svn r5975) -Cleanup: use ORIGINAL_BASE_YEAR & ORIGINAL_MAX_YEAR where the functions really depend on the original date format.
 rubidium parents: 
4295diff
changeset | 24 | |
| 
0bee6d9bc452
(svn r5975) -Cleanup: use ORIGINAL_BASE_YEAR & ORIGINAL_MAX_YEAR where the functions really depend on the original date format.
 rubidium parents: 
4295diff
changeset | 25 | /** The minimum starting year/base year of the original TTD */ | 
| 
0bee6d9bc452
(svn r5975) -Cleanup: use ORIGINAL_BASE_YEAR & ORIGINAL_MAX_YEAR where the functions really depend on the original date format.
 rubidium parents: 
4295diff
changeset | 26 | #define ORIGINAL_BASE_YEAR 1920 | 
| 
0bee6d9bc452
(svn r5975) -Cleanup: use ORIGINAL_BASE_YEAR & ORIGINAL_MAX_YEAR where the functions really depend on the original date format.
 rubidium parents: 
4295diff
changeset | 27 | /** The maximum year of the original TTD */ | 
| 
0bee6d9bc452
(svn r5975) -Cleanup: use ORIGINAL_BASE_YEAR & ORIGINAL_MAX_YEAR where the functions really depend on the original date format.
 rubidium parents: 
4295diff
changeset | 28 | #define ORIGINAL_MAX_YEAR 2090 | 
| 
0bee6d9bc452
(svn r5975) -Cleanup: use ORIGINAL_BASE_YEAR & ORIGINAL_MAX_YEAR where the functions really depend on the original date format.
 rubidium parents: 
4295diff
changeset | 29 | |
| 
0bee6d9bc452
(svn r5975) -Cleanup: use ORIGINAL_BASE_YEAR & ORIGINAL_MAX_YEAR where the functions really depend on the original date format.
 rubidium parents: 
4295diff
changeset | 30 | /** | 
| 
0bee6d9bc452
(svn r5975) -Cleanup: use ORIGINAL_BASE_YEAR & ORIGINAL_MAX_YEAR where the functions really depend on the original date format.
 rubidium parents: 
4295diff
changeset | 31 | * The offset in days from the '_date == 0' till | 
| 
0bee6d9bc452
(svn r5975) -Cleanup: use ORIGINAL_BASE_YEAR & ORIGINAL_MAX_YEAR where the functions really depend on the original date format.
 rubidium parents: 
4295diff
changeset | 32 | * 'ConvertYMDToDate(ORIGINAL_BASE_YEAR, 0, 1)' | 
| 
0bee6d9bc452
(svn r5975) -Cleanup: use ORIGINAL_BASE_YEAR & ORIGINAL_MAX_YEAR where the functions really depend on the original date format.
 rubidium parents: 
4295diff
changeset | 33 | */ | 
| 4326 
c2ae4dbc1074
(svn r5999) -Feature: change the original date format to a 32 bits format based at the year 0.
 rubidium parents: 
4322diff
changeset | 34 | #define DAYS_TILL_ORIGINAL_BASE_YEAR (365 * ORIGINAL_BASE_YEAR + ORIGINAL_BASE_YEAR / 4 - ORIGINAL_BASE_YEAR / 100 + ORIGINAL_BASE_YEAR / 400) | 
| 4322 
0bee6d9bc452
(svn r5975) -Cleanup: use ORIGINAL_BASE_YEAR & ORIGINAL_MAX_YEAR where the functions really depend on the original date format.
 rubidium parents: 
4295diff
changeset | 35 | |
| 
0bee6d9bc452
(svn r5975) -Cleanup: use ORIGINAL_BASE_YEAR & ORIGINAL_MAX_YEAR where the functions really depend on the original date format.
 rubidium parents: 
4295diff
changeset | 36 | /* The absolute minimum & maximum years in OTTD */ | 
| 4326 
c2ae4dbc1074
(svn r5999) -Feature: change the original date format to a 32 bits format based at the year 0.
 rubidium parents: 
4322diff
changeset | 37 | #define MIN_YEAR 0 | 
| 
c2ae4dbc1074
(svn r5999) -Feature: change the original date format to a 32 bits format based at the year 0.
 rubidium parents: 
4322diff
changeset | 38 | /* MAX_YEAR, nicely rounded value of the number of years that can | 
| 
c2ae4dbc1074
(svn r5999) -Feature: change the original date format to a 32 bits format based at the year 0.
 rubidium parents: 
4322diff
changeset | 39 | * be encoded in a single 32 bits date, about 2^31 / 366 years. */ | 
| 
c2ae4dbc1074
(svn r5999) -Feature: change the original date format to a 32 bits format based at the year 0.
 rubidium parents: 
4322diff
changeset | 40 | #define MAX_YEAR 5000000 | 
| 4261 
2ec8f5a9747b
(svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
 rubidium parents: diff
changeset | 41 | |
| 
2ec8f5a9747b
(svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
 rubidium parents: diff
changeset | 42 | /* Year and Date are defined elsewhere */ | 
| 
2ec8f5a9747b
(svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
 rubidium parents: diff
changeset | 43 | typedef uint8 Month; | 
| 
2ec8f5a9747b
(svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
 rubidium parents: diff
changeset | 44 | typedef uint8 Day; | 
| 
2ec8f5a9747b
(svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
 rubidium parents: diff
changeset | 45 | typedef uint16 DateFract; | 
| 
2ec8f5a9747b
(svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
 rubidium parents: diff
changeset | 46 | |
| 6574 
e1d1a12faaf7
(svn r9051) -Codechange: typedef [enum|struct] Y {} X; -> [enum|struct] X {};
 rubidium parents: 
6451diff
changeset | 47 | struct YearMonthDay {
 | 
| 4261 
2ec8f5a9747b
(svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
 rubidium parents: diff
changeset | 48 | Year year; | 
| 
2ec8f5a9747b
(svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
 rubidium parents: diff
changeset | 49 | Month month; | 
| 
2ec8f5a9747b
(svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
 rubidium parents: diff
changeset | 50 | Day day; | 
| 6574 
e1d1a12faaf7
(svn r9051) -Codechange: typedef [enum|struct] Y {} X; -> [enum|struct] X {};
 rubidium parents: 
6451diff
changeset | 51 | }; | 
| 4261 
2ec8f5a9747b
(svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
 rubidium parents: diff
changeset | 52 | |
| 
2ec8f5a9747b
(svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
 rubidium parents: diff
changeset | 53 | extern Year _cur_year; | 
| 
2ec8f5a9747b
(svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
 rubidium parents: diff
changeset | 54 | extern Month _cur_month; | 
| 
2ec8f5a9747b
(svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
 rubidium parents: diff
changeset | 55 | extern Date _date; | 
| 
2ec8f5a9747b
(svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
 rubidium parents: diff
changeset | 56 | extern DateFract _date_fract; | 
| 
2ec8f5a9747b
(svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
 rubidium parents: diff
changeset | 57 | |
| 
2ec8f5a9747b
(svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
 rubidium parents: diff
changeset | 58 | |
| 
2ec8f5a9747b
(svn r5887) -Cleanup: move date related functions, defines and variables to date.[ch]
 rubidium parents: diff
changeset | 59 | void SetDate(Date date); | 
| 4288 
60398d0e64ee
(svn r5918) -Cleanup: rename ConvertDayToYMD/ConvertYMDToDay as they really convert a Date to/from a YearMonthDay.
 rubidium parents: 
4286diff
changeset | 60 | void ConvertDateToYMD(Date date, YearMonthDay *ymd); | 
| 
60398d0e64ee
(svn r5918) -Cleanup: rename ConvertDayToYMD/ConvertYMDToDay as they really convert a Date to/from a YearMonthDay.
 rubidium parents: 
4286diff
changeset | 61 | Date ConvertYMDToDate(Year year, Month month, Day day); | 
| 4666 
850b5b6e4bac
(svn r6560) - Codechange: Minor fix; add missing #include guards and comments, and correct svn properties on bmp.[ch]
 peter1138 parents: 
4329diff
changeset | 62 | |
| 
850b5b6e4bac
(svn r6560) - Codechange: Minor fix; add missing #include guards and comments, and correct svn properties on bmp.[ch]
 peter1138 parents: 
4329diff
changeset | 63 | #endif /* DATE_H */ |