⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 getdate.c

📁 netflow,抓包
💻 C
📖 第 1 页 / 共 4 页
字号:
/*  { "second",		tUNUMBER,	2 }, */    { "third",		tUNUMBER,	3 },    { "fourth",		tUNUMBER,	4 },    { "fifth",		tUNUMBER,	5 },    { "sixth",		tUNUMBER,	6 },    { "seventh",	tUNUMBER,	7 },    { "eighth",		tUNUMBER,	8 },    { "ninth",		tUNUMBER,	9 },    { "tenth",		tUNUMBER,	10 },    { "eleventh",	tUNUMBER,	11 },    { "twelfth",	tUNUMBER,	12 },    { "ago",		tAGO,	1 },    { NULL }};/* The timezone table. */static TABLE const TimezoneTable[] = {    { "gmt",	tZONE,     HOUR ( 0) },	/* Greenwich Mean */    { "ut",	tZONE,     HOUR ( 0) },	/* Universal (Coordinated) */    { "utc",	tZONE,     HOUR ( 0) },    { "wet",	tZONE,     HOUR ( 0) },	/* Western European */    { "bst",	tDAYZONE,  HOUR ( 0) },	/* British Summer */    { "wat",	tZONE,     HOUR ( 1) },	/* West Africa */    { "at",	tZONE,     HOUR ( 2) },	/* Azores */#if	0    /* For completeness.  BST is also British Summer, and GST is     * also Guam Standard. */    { "bst",	tZONE,     HOUR ( 3) },	/* Brazil Standard */    { "gst",	tZONE,     HOUR ( 3) },	/* Greenland Standard */#endif#if 0    { "nft",	tZONE,     HOUR (3.5) },	/* Newfoundland */    { "nst",	tZONE,     HOUR (3.5) },	/* Newfoundland Standard */    { "ndt",	tDAYZONE,  HOUR (3.5) },	/* Newfoundland Daylight */#endif    { "ast",	tZONE,     HOUR ( 4) },	/* Atlantic Standard */    { "adt",	tDAYZONE,  HOUR ( 4) },	/* Atlantic Daylight */    { "est",	tZONE,     HOUR ( 5) },	/* Eastern Standard */    { "edt",	tDAYZONE,  HOUR ( 5) },	/* Eastern Daylight */    { "cst",	tZONE,     HOUR ( 6) },	/* Central Standard */    { "cdt",	tDAYZONE,  HOUR ( 6) },	/* Central Daylight */    { "mst",	tZONE,     HOUR ( 7) },	/* Mountain Standard */    { "mdt",	tDAYZONE,  HOUR ( 7) },	/* Mountain Daylight */    { "pst",	tZONE,     HOUR ( 8) },	/* Pacific Standard */    { "pdt",	tDAYZONE,  HOUR ( 8) },	/* Pacific Daylight */    { "yst",	tZONE,     HOUR ( 9) },	/* Yukon Standard */    { "ydt",	tDAYZONE,  HOUR ( 9) },	/* Yukon Daylight */    { "hst",	tZONE,     HOUR (10) },	/* Hawaii Standard */    { "hdt",	tDAYZONE,  HOUR (10) },	/* Hawaii Daylight */    { "cat",	tZONE,     HOUR (10) },	/* Central Alaska */    { "ahst",	tZONE,     HOUR (10) },	/* Alaska-Hawaii Standard */    { "nt",	tZONE,     HOUR (11) },	/* Nome */    { "idlw",	tZONE,     HOUR (12) },	/* International Date Line West */    { "cet",	tZONE,     -HOUR (1) },	/* Central European */    { "met",	tZONE,     -HOUR (1) },	/* Middle European */    { "mewt",	tZONE,     -HOUR (1) },	/* Middle European Winter */    { "mest",	tDAYZONE,  -HOUR (1) },	/* Middle European Summer */    { "mesz",	tDAYZONE,  -HOUR (1) },	/* Middle European Summer */    { "swt",	tZONE,     -HOUR (1) },	/* Swedish Winter */    { "sst",	tDAYZONE,  -HOUR (1) },	/* Swedish Summer */    { "fwt",	tZONE,     -HOUR (1) },	/* French Winter */    { "fst",	tDAYZONE,  -HOUR (1) },	/* French Summer */    { "eet",	tZONE,     -HOUR (2) },	/* Eastern Europe, USSR Zone 1 */    { "bt",	tZONE,     -HOUR (3) },	/* Baghdad, USSR Zone 2 */#if 0    { "it",	tZONE,     -HOUR (3.5) },/* Iran */#endif    { "zp4",	tZONE,     -HOUR (4) },	/* USSR Zone 3 */    { "zp5",	tZONE,     -HOUR (5) },	/* USSR Zone 4 */#if 0    { "ist",	tZONE,     -HOUR (5.5) },/* Indian Standard */#endif    { "zp6",	tZONE,     -HOUR (6) },	/* USSR Zone 5 */#if	0    /* For completeness.  NST is also Newfoundland Standard, and SST is     * also Swedish Summer. */    { "nst",	tZONE,     -HOUR (6.5) },/* North Sumatra */    { "sst",	tZONE,     -HOUR (7) },	/* South Sumatra, USSR Zone 6 */#endif	/* 0 */    { "wast",	tZONE,     -HOUR (7) },	/* West Australian Standard */    { "wadt",	tDAYZONE,  -HOUR (7) },	/* West Australian Daylight */#if 0    { "jt",	tZONE,     -HOUR (7.5) },/* Java (3pm in Cronusland!) */#endif    { "cct",	tZONE,     -HOUR (8) },	/* China Coast, USSR Zone 7 */    { "jst",	tZONE,     -HOUR (9) },	/* Japan Standard, USSR Zone 8 */#if 0    { "cast",	tZONE,     -HOUR (9.5) },/* Central Australian Standard */    { "cadt",	tDAYZONE,  -HOUR (9.5) },/* Central Australian Daylight */#endif    { "east",	tZONE,     -HOUR (10) },	/* Eastern Australian Standard */    { "eadt",	tDAYZONE,  -HOUR (10) },	/* Eastern Australian Daylight */    { "gst",	tZONE,     -HOUR (10) },	/* Guam Standard, USSR Zone 9 */    { "nzt",	tZONE,     -HOUR (12) },	/* New Zealand */    { "nzst",	tZONE,     -HOUR (12) },	/* New Zealand Standard */    { "nzdt",	tDAYZONE,  -HOUR (12) },	/* New Zealand Daylight */    { "idle",	tZONE,     -HOUR (12) },	/* International Date Line East */    {  NULL  }};/* Military timezone table. */static TABLE const MilitaryTable[] = {    { "a",	tZONE,	HOUR (  1) },    { "b",	tZONE,	HOUR (  2) },    { "c",	tZONE,	HOUR (  3) },    { "d",	tZONE,	HOUR (  4) },    { "e",	tZONE,	HOUR (  5) },    { "f",	tZONE,	HOUR (  6) },    { "g",	tZONE,	HOUR (  7) },    { "h",	tZONE,	HOUR (  8) },    { "i",	tZONE,	HOUR (  9) },    { "k",	tZONE,	HOUR ( 10) },    { "l",	tZONE,	HOUR ( 11) },    { "m",	tZONE,	HOUR ( 12) },    { "n",	tZONE,	HOUR (- 1) },    { "o",	tZONE,	HOUR (- 2) },    { "p",	tZONE,	HOUR (- 3) },    { "q",	tZONE,	HOUR (- 4) },    { "r",	tZONE,	HOUR (- 5) },    { "s",	tZONE,	HOUR (- 6) },    { "t",	tZONE,	HOUR (- 7) },    { "u",	tZONE,	HOUR (- 8) },    { "v",	tZONE,	HOUR (- 9) },    { "w",	tZONE,	HOUR (-10) },    { "x",	tZONE,	HOUR (-11) },    { "y",	tZONE,	HOUR (-12) },    { "z",	tZONE,	HOUR (  0) },    { NULL }};/* ARGSUSED */static int yyerror (char *s){  return 0;}static int ToHour (int Hours, MERIDIAN Meridian){  switch (Meridian)    {    case MER24:      if (Hours < 0 || Hours > 23)	return -1;      return Hours;    case MERam:      if (Hours < 1 || Hours > 12)	return -1;      if (Hours == 12)	Hours = 0;      return Hours;    case MERpm:      if (Hours < 1 || Hours > 12)	return -1;      if (Hours == 12)	Hours = 0;      return Hours + 12;    default:      abort ();    }  /* NOTREACHED */}static int ToYear (int Year){  if (Year < 0)    Year = -Year;  /* XPG4 suggests that years 00-68 map to 2000-2068, and     years 69-99 map to 1969-1999.  */  if (Year < 69)    Year += 2000;  else if (Year < 100)    Year += 1900;  return Year;}static int LookupWord (char *buff){  register char *p;  register char *q;  register const TABLE *tp;  int i;  int abbrev;  /* Make it lowercase. */  for (p = buff; *p; p++)    if (ISUPPER (*p))      *p = tolower (*p);  if (strcmp (buff, "am") == 0 || strcmp (buff, "a.m.") == 0)    {      yylval.Meridian = MERam;      return tMERIDIAN;    }  if (strcmp (buff, "pm") == 0 || strcmp (buff, "p.m.") == 0)    {      yylval.Meridian = MERpm;      return tMERIDIAN;    }  /* See if we have an abbreviation for a month. */  if (strlen (buff) == 3)    abbrev = 1;  else if (strlen (buff) == 4 && buff[3] == '.')    {      abbrev = 1;      buff[3] = '\0';    }  else    abbrev = 0;  for (tp = MonthDayTable; tp->name; tp++)    {      if (abbrev)	{	  if (strncmp (buff, tp->name, 3) == 0)	    {	      yylval.Number = tp->value;	      return tp->type;	    }	}      else if (strcmp (buff, tp->name) == 0)	{	  yylval.Number = tp->value;	  return tp->type;	}    }  for (tp = TimezoneTable; tp->name; tp++)    if (strcmp (buff, tp->name) == 0)      {	yylval.Number = tp->value;	return tp->type;      }  if (strcmp (buff, "dst") == 0)    return tDST;  for (tp = UnitsTable; tp->name; tp++)    if (strcmp (buff, tp->name) == 0)      {	yylval.Number = tp->value;	return tp->type;      }  /* Strip off any plural and try the units table again. */  i = strlen (buff) - 1;  if (buff[i] == 's')    {      buff[i] = '\0';      for (tp = UnitsTable; tp->name; tp++)	if (strcmp (buff, tp->name) == 0)	  {	    yylval.Number = tp->value;	    return tp->type;	  }      buff[i] = 's';		/* Put back for "this" in OtherTable. */    }  for (tp = OtherTable; tp->name; tp++)    if (strcmp (buff, tp->name) == 0)      {	yylval.Number = tp->value;	return tp->type;      }  /* Military timezones. */  if (buff[1] == '\0' && ISALPHA (*buff))    {      for (tp = MilitaryTable; tp->name; tp++)	if (strcmp (buff, tp->name) == 0)	  {	    yylval.Number = tp->value;	    return tp->type;	  }    }  /* Drop out any periods and try the timezone table again. */  for (i = 0, p = q = buff; *q; q++)    if (*q != '.')      *p++ = *q;    else      i++;  *p = '\0';  if (i)    for (tp = TimezoneTable; tp->name; tp++)      if (strcmp (buff, tp->name) == 0)	{	  yylval.Number = tp->value;	  return tp->type;	}  return tID;}static int yylex (void){  register char c;  register char *p;  char buff[20];  int Count;  int sign;  for (;;)    {      while (ISSPACE (*yyInput))	yyInput++;      if (ISDIGIT (c = *yyInput) || c == '-' || c == '+')	{	  if (c == '-' || c == '+')	    {	      sign = c == '-' ? -1 : 1;	      if (!ISDIGIT (*++yyInput))		/* skip the '-' sign */		continue;	    }	  else	    sign = 0;	  for (yylval.Number = 0; ISDIGIT (c = *yyInput++);)	    yylval.Number = 10 * yylval.Number + c - '0';	  yyInput--;	  if (sign < 0)	    yylval.Number = -yylval.Number;	  return sign ? tSNUMBER : tUNUMBER;	}      if (ISALPHA (c))	{	  for (p = buff; (c = *yyInput++, ISALPHA (c)) || c == '.';)	    if (p < &buff[sizeof buff - 1])	      *p++ = c;	  *p = '\0';	  yyInput--;	  return LookupWord (buff);	}      if (c != '(')	return *yyInput++;      Count = 0;      do	{	  c = *yyInput++;	  if (c == '\0')	    return c;	  if (c == '(')	    Count++;	  else if (c == ')')	    Count--;	}      while (Count > 0);    }}#define TM_YEAR_ORIGIN 1900/* Yield A - B, measured in seconds.  */static long difftm (struct tm *a, struct tm *b){  int ay = a->tm_year + (TM_YEAR_ORIGIN - 1);  int by = b->tm_year + (TM_YEAR_ORIGIN - 1);  long days = (  /* difference in day of year */		a->tm_yday - b->tm_yday  /* + intervening leap days */		+ ((ay >> 2) - (by >> 2))		- (ay / 100 - by / 100)		+ ((ay / 100 >> 2) - (by / 100 >> 2))  /* + difference in years * 365 */		+ (long) (ay - by) * 365  );  return (60 * (60 * (24 * days + (a->tm_hour - b->tm_hour))		+ (a->tm_min - b->tm_min))	  + (a->tm_sec - b->tm_sec));}time_t get_date (const char *p, const time_t *now){  struct tm tm, tm0, *tmp;  time_t Start;  yyInput = p;  Start = now ? *now : time ((time_t *) NULL);  tmp = localtime (&Start);  yyYear = tmp->tm_year + TM_YEAR_ORIGIN;  yyMonth = tmp->tm_mon + 1;  yyDay = tmp->tm_mday;  yyHour = tmp->tm_hour;  yyMinutes = tmp->tm_min;  yySeconds = tmp->tm_sec;  yyMeridian = MER24;  yyRelSeconds = 0;  yyRelMinutes = 0;  yyRelHour = 0;  yyRelDay = 0;  yyRelMonth = 0;  yyRelYear = 0;  yyHaveDate = 0;  yyHaveDay = 0;  yyHaveRel = 0;  yyHaveTime = 0;  yyHaveZone = 0;  if (yyparse ()      || yyHaveTime > 1 || yyHaveZone > 1 || yyHaveDate > 1 || yyHaveDay > 1)    return -1;  tm.tm_year = ToYear (yyYear) - TM_YEAR_ORIGIN + yyRelYear;  tm.tm_mon = yyMonth - 1 + yyRelMonth;  tm.tm_mday = yyDay + yyRelDay;  if (yyHaveTime || (yyHaveRel && !yyHaveDate && !yyHaveDay))    {      tm.tm_hour = ToHour (yyHour, yyMeridian);      if (tm.tm_hour < 0)	return -1;      tm.tm_min = yyMinutes;      tm.tm_sec = yySeconds;    }  else    {      tm.tm_hour = tm.tm_min = tm.tm_sec = 0;    }  tm.tm_hour += yyRelHour;  tm.tm_min += yyRelMinutes;  tm.tm_sec += yyRelSeconds;  tm.tm_isdst = -1;  tm0 = tm;  Start = mktime (&tm);  if (Start == (time_t) -1)    {      /* Guard against falsely reporting errors near the time_t boundaries         when parsing times in other time zones.  For example, if the min         time_t value is 1970-01-01 00:00:00 UTC and we are 8 hours ahead         of UTC, then the min localtime value is 1970-01-01 08:00:00; if         we apply mktime to 1970-01-01 00:00:00 we will get an error, so         we apply mktime to 1970-01-02 08:00:00 instead and adjust the time         zone by 24 hours to compensate.  This algorithm assumes that         there is no DST transition within a day of the time_t boundaries.  */      if (yyHaveZone)	{	  tm = tm0;	  if (tm.tm_year <= EPOCH - TM_YEAR_ORIGIN)	    {	      tm.tm_mday++;	      yyTimezone -= 24 * 60;	    }	  else	    {	      tm.tm_mday--;	      yyTimezone += 24 * 60;	    }	  Start = mktime (&tm);	}      if (Start == (time_t) -1)	return Start;    }  if (yyHaveDay && !yyHaveDate)    {      tm.tm_mday += ((yyDayNumber - tm.tm_wday + 7) % 7		     + 7 * (yyDayOrdinal - (0 < yyDayOrdinal)));      Start = mktime (&tm);      if (Start == (time_t) -1)	return Start;    }  if (yyHaveZone)    {      long delta = yyTimezone * 60L + difftm (&tm, gmtime (&Start));      if ((Start + delta < Start) != (delta < 0))	return -1;		/* time_t overflow */      Start += delta;    }  return Start;}#if	defined (TEST)/* ARGSUSED */int main (int ac, char *av[]){  char buff[MAX_BUFF_LEN + 1];  time_t d;  (void) printf ("Enter date, or blank line to exit.\n\t> ");  (void) fflush (stdout);  buff[MAX_BUFF_LEN] = 0;  while (fgets (buff, MAX_BUFF_LEN, stdin) && buff[0])    {      d = get_date (buff, (time_t *) NULL);      if (d == -1)	(void) printf ("Bad format - couldn't convert.\n");      else	(void) printf ("%s", ctime (&d));      (void) printf ("\t> ");      (void) fflush (stdout);    }  exit (0);  /* NOTREACHED */}#endif /* defined (TEST) */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -