1/*- 2 * SPDX-License-Identifier: BSD-3-Clause 3 * 4 * Copyright (c) 1989, 1993, 1994 5 * The Regents of the University of California. All rights reserved. 6 * 7 * Redistribution and use in source and binary forms, with or without 8 * modification, are permitted provided that the following conditions 9 * are met: 10 * 1. Redistributions of source code must retain the above copyright 11 * notice, this list of conditions and the following disclaimer. 12 * 2. Redistributions in binary form must reproduce the above copyright 13 * notice, this list of conditions and the following disclaimer in the 14 * documentation and/or other materials provided with the distribution. 15 * 3. Neither the name of the University nor the names of its contributors 16 * may be used to endorse or promote products derived from this software 17 * without specific prior written permission. 18 * 19 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 20 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 21 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 22 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 23 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 24 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 25 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 26 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 27 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 28 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 29 * SUCH DAMAGE. 30 */ 31 32#include <sys/types.h> 33#include <sys/uio.h> 34 35#define SECSPERDAY (24 * 60 * 60) 36#define SECSPERHOUR (60 * 60) 37#define SECSPERMINUTE (60) 38#define MINSPERHOUR (60) 39#define HOURSPERDAY (24) 40#define FSECSPERDAY (24.0 * 60.0 * 60.0) 41#define FSECSPERHOUR (60.0 * 60.0) 42#define FSECSPERMINUTE (60.0) 43#define FMINSPERHOUR (60.0) 44#define FHOURSPERDAY (24.0) 45 46#define DAYSPERYEAR 365 47#define DAYSPERLEAPYEAR 366 48 49/* Not yet categorized */ 50 51extern struct passwd *pw; 52extern int doall; 53extern time_t t1, t2; 54extern const char *calendarFile; 55extern int yrdays; 56extern struct fixs neaster, npaskha, ncny, nfullmoon, nnewmoon; 57extern struct fixs nmarequinox, nsepequinox, njunsolstice, ndecsolstice; 58extern double UTCOffset; 59extern int EastLongitude; 60#ifdef WITH_ICONV 61extern const char *outputEncoding; 62#endif 63 64#define isleap(y) ((((y) % 4) == 0 && ((y) % 100) != 0) || ((y) % 400) == 0) 65 66/* Flags to determine the returned values by determinestyle() in parsedata.c */ 67#define F_NONE 0x00000 68#define F_MONTH 0x00001 69#define F_DAYOFWEEK 0x00002 70#define F_DAYOFMONTH 0x00004 71#define F_MODIFIERINDEX 0x00008 72#define F_MODIFIEROFFSET 0x00010 73#define F_SPECIALDAY 0x00020 74#define F_ALLMONTH 0x00040 75#define F_ALLDAY 0x00080 76#define F_VARIABLE 0x00100 77#define F_EASTER 0x00200 78#define F_CNY 0x00400 79#define F_PASKHA 0x00800 80#define F_NEWMOON 0x01000 81#define F_FULLMOON 0x02000 82#define F_MAREQUINOX 0x04000 83#define F_SEPEQUINOX 0x08000 84#define F_JUNSOLSTICE 0x10000 85#define F_DECSOLSTICE 0x20000 86#define F_YEAR 0x40000 87 88#define STRING_EASTER "Easter" 89#define STRING_PASKHA "Paskha" 90#define STRING_CNY "ChineseNewYear" 91#define STRING_NEWMOON "NewMoon" 92#define STRING_FULLMOON "FullMoon" 93#define STRING_MAREQUINOX "MarEquinox" 94#define STRING_SEPEQUINOX "SepEquinox" 95#define STRING_JUNSOLSTICE "JunSolstice" 96#define STRING_DECSOLSTICE "DecSolstice" 97 98#define MAXCOUNT 125 /* Random number of maximum number of 99 * repeats of an event. Should be 52 100 * (number of weeks per year), if you 101 * want to show two years then it 102 * should be 104. If you are seeing 103 * more than this you are using this 104 * program wrong. 105 */ 106 107/* 108 * All the astronomical calculations are carried out for the meridian 120 109 * degrees east of Greenwich. 110 */ 111#define UTCOFFSET_CNY 8.0 112 113extern int debug; /* show parsing of the input */ 114extern int year1, year2; 115 116/* events.c */ 117/* 118 * Event sorting related functions: 119 * - Use event_add() to create a new event 120 * - Use event_continue() to add more text to the last added event 121 * - Use event_print_all() to display them in time chronological order 122 */ 123struct event *event_add(int, int, int, int, char *, char *); 124void event_continue(struct event *events, char *txt); 125void event_print_all(FILE *fp); 126struct event { 127 int year; 128 int month; 129 int day; 130 int var; 131 char *text; 132 char *extra; 133 struct event *next; 134}; 135 136/* locale.c */ 137 138struct fixs { 139 char *name; 140 size_t len; 141}; 142 143extern const char *days[]; 144extern const char *fdays[]; 145extern const char *fmonths[]; 146extern const char *months[]; 147extern const char *sequences[]; 148extern struct fixs fndays[8]; /* full national days names */ 149extern struct fixs fnmonths[13]; /* full national months names */ 150extern struct fixs ndays[8]; /* short national days names */ 151extern struct fixs nmonths[13]; /* short national month names */ 152extern struct fixs nsequences[10]; 153 154void setnnames(void); 155void setnsequences(char *); 156 157/* day.c */ 158extern const struct tm tm0; 159extern char dayname[]; 160void settimes(time_t,int before, int after, int friday, struct tm *tp1, struct tm *tp2); 161time_t Mktime(char *); 162 163/* parsedata.c */ 164int parsedaymonth(char *, int *, int *, int *, int *, char **); 165void dodebug(char *type); 166 167/* io.c */ 168void cal(void); 169void closecal(FILE *); 170FILE *opencalin(void); 171FILE *opencalout(void); 172 173/* ostern.c / paskha.c */ 174int paskha(int); 175int easter(int); 176int j2g(int); 177 178/* dates.c */ 179extern int cumdaytab[][14]; 180extern int monthdaytab[][14]; 181extern int debug_remember; 182void generatedates(struct tm *tp1, struct tm *tp2); 183void dumpdates(void); 184int remember_ymd(int y, int m, int d); 185int remember_yd(int y, int d, int *rm, int *rd); 186int first_dayofweek_of_year(int y); 187int first_dayofweek_of_month(int y, int m); 188int walkthrough_dates(struct event **e); 189void addtodate(struct event *e); 190 191/* pom.c */ 192#define MAXMOONS 18 193void pom(int year, double UTCoffset, int *fms, int *nms); 194void fpom(int year, double utcoffset, double *ffms, double *fnms); 195 196/* sunpos.c */ 197void equinoxsolstice(int year, double UTCoffset, int *equinoxdays, int *solsticedays); 198void fequinoxsolstice(int year, double UTCoffset, double *equinoxdays, double *solsticedays); 199int calculatesunlongitude30(int year, int degreeGMToffset, int *ichinesemonths); 200 201#ifdef WITH_ICONV 202void set_new_encoding(void); 203#endif 204