diff options
-rw-r--r-- | generic/tclDate.c | 160 | ||||
-rw-r--r-- | generic/tclGetDate.y | 18 | ||||
-rw-r--r-- | tests/clock.test | 18 |
3 files changed, 122 insertions, 74 deletions
diff --git a/generic/tclDate.c b/generic/tclDate.c index 7da7e59..b88156b 100644 --- a/generic/tclDate.c +++ b/generic/tclDate.c @@ -10,7 +10,7 @@ * See the file "license.terms" for information on usage and redistribution * of this file, and for a DISCLAIMER OF ALL WARRANTIES. * - * RCS: @(#) $Id: tclDate.c,v 1.13 2000/01/12 19:36:41 ericm Exp $ + * RCS: @(#) $Id: tclDate.c,v 1.14 2000/01/12 23:35:52 ericm Exp $ */ #include "tclInt.h" @@ -137,6 +137,7 @@ typedef union # define tDST 270 # define tISOBASE 271 # define tDAY_UNIT 272 +# define tNEXT 273 @@ -240,7 +241,7 @@ static TABLE OtherTable[] = { { "now", tSEC_UNIT, 0 }, { "last", tUNUMBER, -1 }, { "this", tSEC_UNIT, 0 }, - { "next", tUNUMBER, 1 }, + { "next", tNEXT, 1 }, #if 0 { "first", tUNUMBER, 1 }, { "second", tUNUMBER, 2 }, @@ -880,21 +881,21 @@ static CONST TclDatetabelem TclDateexca[] ={ 0, -1, -2, 0, }; -# define YYNPROD 47 -# define YYLAST 247 +# define YYNPROD 51 +# define YYLAST 256 static CONST TclDatetabelem TclDateact[]={ - 20, 46, 19, 23, 21, 45, 32, 31, 41, 33, - 69, 22, 42, 68, 28, 64, 27, 63, 62, 61, - 60, 59, 57, 43, 40, 39, 36, 25, 34, 50, - 66, 38, 49, 67, 56, 37, 53, 55, 54, 47, - 35, 18, 51, 9, 8, 7, 6, 5, 4, 3, - 2, 1, 30, 17, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 44, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 48, 0, - 0, 0, 0, 0, 58, 0, 0, 0, 0, 0, - 0, 0, 0, 65, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, + 21, 38, 20, 33, 32, 52, 34, 24, 22, 75, + 40, 24, 22, 24, 22, 23, 72, 74, 29, 23, + 28, 23, 50, 45, 70, 69, 49, 46, 68, 67, + 66, 26, 65, 63, 47, 44, 43, 37, 35, 56, + 42, 55, 73, 62, 41, 59, 61, 60, 51, 36, + 19, 9, 57, 8, 7, 6, 5, 4, 3, 2, + 1, 31, 17, 0, 0, 0, 0, 0, 0, 39, + 0, 0, 0, 0, 0, 0, 48, 0, 0, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 53, 0, + 0, 54, 0, 0, 0, 0, 0, 0, 64, 0, + 0, 0, 0, 0, 0, 0, 0, 0, 71, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, @@ -906,54 +907,60 @@ static CONST TclDatetabelem TclDateact[]={ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 16, 12, 0, 0, 0, - 14, 23, 21, 0, 10, 11, 15, 26, 13, 22, - 24, 0, 29, 23, 21, 0, 0, 0, 0, 0, - 0, 22, 0, 0, 0, 52, 52 }; + 14, 24, 22, 0, 10, 11, 15, 0, 13, 23, + 18, 27, 58, 0, 25, 0, 30, 24, 22, 0, + 0, 0, 0, 0, 0, 23, 0, 0, 0, 0, + 0, 0, 0, 0, 0, 58 }; static CONST TclDatetabelem TclDatepact[]={ -10000000, -43,-10000000,-10000000,-10000000,-10000000,-10000000,-10000000,-10000000,-10000000, - -31, -263,-10000000, -262, -239,-10000000, -4, -241, -226,-10000000, --10000000,-10000000,-10000000,-10000000,-10000000, -242,-10000000, -243, -255, -244, - -226,-10000000, -266,-10000000, -5,-10000000, -261,-10000000,-10000000, -16, - -11, -7, -8,-10000000,-10000000,-10000000, -24, -245, -226,-10000000, - -246, -247,-10000000, -248, -249, -250, -252,-10000000,-10000000,-10000000, - -15,-10000000,-10000000,-10000000, -25,-10000000, -254, -257,-10000000,-10000000 }; + -27, -266,-10000000, -265, -229,-10000000, 5, -230, -257, -217, +-10000000,-10000000,-10000000,-10000000,-10000000,-10000000, -231,-10000000, -232, -240, + -233, -217,-10000000, -245,-10000000, 4,-10000000, -253,-10000000,-10000000, + -251,-10000000,-10000000, -6, -2, 2, 1,-10000000,-10000000,-10000000, + -15, -234,-10000000, -217,-10000000,-10000000, -235, -237,-10000000, -238, + -239, -242, -243,-10000000,-10000000,-10000000, -29,-10000000,-10000000,-10000000, + -16,-10000000, -250, -258,-10000000,-10000000 }; static CONST TclDatetabelem TclDatepgo[]={ - 0, 41, 35, 53, 32, 51, 50, 49, 48, 47, - 46, 45, 44, 43 }; + 0, 50, 44, 62, 41, 60, 59, 58, 57, 56, + 55, 54, 53, 51 }; static CONST TclDatetabelem TclDater1[]={ 0, 5, 5, 6, 6, 6, 6, 6, 6, 6, 7, 7, 7, 7, 7, 8, 8, 8, 10, 10, - 10, 9, 9, 9, 9, 9, 9, 9, 9, 9, - 9, 12, 12, 12, 11, 11, 11, 3, 3, 1, - 1, 1, 2, 2, 13, 4, 4 }; + 10, 10, 10, 9, 9, 9, 9, 9, 9, 9, + 9, 9, 9, 12, 12, 12, 11, 11, 11, 11, + 11, 3, 3, 1, 1, 1, 2, 2, 13, 4, + 4 }; static CONST TclDatetabelem TclDater2[]={ 0, 0, 4, 3, 3, 3, 3, 3, 3, 2, 5, 9, 11, 13, 15, 5, 3, 3, 3, 5, - 5, 7, 11, 3, 11, 11, 5, 9, 5, 3, - 7, 7, 15, 5, 9, 7, 5, 3, 3, 3, - 3, 3, 3, 1, 3, 1, 3 }; + 5, 7, 5, 7, 11, 3, 11, 11, 5, 9, + 5, 3, 7, 7, 15, 5, 9, 7, 5, 7, + 5, 3, 3, 3, 3, 3, 3, 1, 3, 1, + 3 }; static CONST TclDatetabelem TclDatechk[]={ -10000000, -5, -6, -7, -8, -9, -10, -11, -12, -13, - 267, 268, 259, 271, 263, 269, 258, -3, -1, 45, - 43, 265, 272, 264, 261, 58, 258, 47, 45, 263, - -1, 270, 268, 271, 267, 44, 267, -2, 257, 267, - 267, 263, 267, 267, -2, 271, 267, 44, -1, -4, - 45, 58, 261, 47, 45, 45, 58, 267, -2, 267, - 267, 267, 267, 267, 267, -4, 45, 58, 267, 267 }; + 267, 268, 259, 271, 263, 269, 258, -3, 273, -1, + 45, 43, 265, 272, 264, 261, 58, 258, 47, 45, + 263, -1, 270, 268, 271, 267, 44, 267, 258, -1, + 267, -2, 257, 267, 267, 263, 267, 267, -2, 271, + 267, 44, 258, -1, -1, -4, 45, 58, 261, 47, + 45, 45, 58, 267, -2, 267, 267, 267, 267, 267, + 267, -4, 45, 58, 267, 267 }; static CONST TclDatetabelem TclDatedef[]={ 1, -2, 2, 3, 4, 5, 6, 7, 8, 9, - 44, 16, 17, 23, 0, 29, 18, 0, 43, 37, - 38, 39, 40, 41, 10, 0, 20, 0, 0, 28, - 43, 15, 0, 33, 26, 19, 0, 36, 42, 45, - 21, 0, 0, 30, 35, 31, 0, 0, 43, 11, - 0, 0, 46, 0, 0, 0, 0, 27, 34, 12, - 45, 22, 24, 25, 0, 13, 0, 0, 14, 32 }; + 48, 16, 17, 25, 0, 31, 18, 0, 0, 47, + 41, 42, 43, 44, 45, 10, 0, 20, 0, 0, + 30, 47, 15, 0, 35, 28, 19, 0, 22, 38, + 0, 40, 46, 49, 23, 0, 0, 32, 37, 33, + 0, 0, 21, 47, 39, 11, 0, 0, 50, 0, + 0, 0, 0, 29, 36, 12, 49, 24, 26, 27, + 0, 13, 0, 0, 14, 34 }; typedef struct #ifdef __cplusplus TclDatetoktype @@ -983,6 +990,7 @@ TclDatetoktype TclDatetoks[] = "tDST", 270, "tISOBASE", 271, "tDAY_UNIT", 272, + "tNEXT", 273, "-unknown-", -1 /* ends search */ }; @@ -1009,6 +1017,8 @@ char * TclDatereds[] = "day : tDAY", "day : tDAY ','", "day : tUNUMBER tDAY", + "day : sign tUNUMBER tDAY", + "day : tNEXT tDAY", "date : tUNUMBER '/' tUNUMBER", "date : tUNUMBER '/' tUNUMBER '/' tUNUMBER", "date : tISOBASE", @@ -1024,6 +1034,8 @@ char * TclDatereds[] = "iso : tISOBASE tISOBASE", "relspec : sign tUNUMBER unit ago", "relspec : tUNUMBER unit ago", + "relspec : tNEXT unit", + "relspec : tNEXT tUNUMBER unit", "relspec : unit ago", "sign : '-'", "sign : '+'", @@ -1641,53 +1653,61 @@ case 20:{ TclDateDayNumber = TclDatepvt[-0].Number; } break; case 21:{ + TclDateDayOrdinal = TclDatepvt[-2].Number * TclDatepvt[-1].Number; + TclDateDayNumber = TclDatepvt[-0].Number; + } break; +case 22:{ + TclDateDayOrdinal = 2; + TclDateDayNumber = TclDatepvt[-0].Number; + } break; +case 23:{ TclDateMonth = TclDatepvt[-2].Number; TclDateDay = TclDatepvt[-0].Number; } break; -case 22:{ +case 24:{ TclDateMonth = TclDatepvt[-4].Number; TclDateDay = TclDatepvt[-2].Number; TclDateYear = TclDatepvt[-0].Number; } break; -case 23:{ +case 25:{ TclDateYear = TclDatepvt[-0].Number / 10000; TclDateMonth = (TclDatepvt[-0].Number % 10000)/100; TclDateDay = TclDatepvt[-0].Number % 100; } break; -case 24:{ +case 26:{ TclDateDay = TclDatepvt[-4].Number; TclDateMonth = TclDatepvt[-2].Number; TclDateYear = TclDatepvt[-0].Number; } break; -case 25:{ +case 27:{ TclDateMonth = TclDatepvt[-2].Number; TclDateDay = TclDatepvt[-0].Number; TclDateYear = TclDatepvt[-4].Number; } break; -case 26:{ +case 28:{ TclDateMonth = TclDatepvt[-1].Number; TclDateDay = TclDatepvt[-0].Number; } break; -case 27:{ +case 29:{ TclDateMonth = TclDatepvt[-3].Number; TclDateDay = TclDatepvt[-2].Number; TclDateYear = TclDatepvt[-0].Number; } break; -case 28:{ +case 30:{ TclDateMonth = TclDatepvt[-0].Number; TclDateDay = TclDatepvt[-1].Number; } break; -case 29:{ +case 31:{ TclDateMonth = 1; TclDateDay = 1; TclDateYear = EPOCH; } break; -case 30:{ +case 32:{ TclDateMonth = TclDatepvt[-1].Number; TclDateDay = TclDatepvt[-2].Number; TclDateYear = TclDatepvt[-0].Number; } break; -case 31:{ +case 33:{ if (TclDatepvt[-1].Number != HOUR(- 7)) YYABORT; TclDateYear = TclDatepvt[-2].Number / 10000; TclDateMonth = (TclDatepvt[-2].Number % 10000)/100; @@ -1696,7 +1716,7 @@ case 31:{ TclDateMinutes = (TclDatepvt[-0].Number % 10000)/100; TclDateSeconds = TclDatepvt[-0].Number % 100; } break; -case 32:{ +case 34:{ if (TclDatepvt[-5].Number != HOUR(- 7)) YYABORT; TclDateYear = TclDatepvt[-6].Number / 10000; TclDateMonth = (TclDatepvt[-6].Number % 10000)/100; @@ -1705,7 +1725,7 @@ case 32:{ TclDateMinutes = TclDatepvt[-2].Number; TclDateSeconds = TclDatepvt[-0].Number; } break; -case 33:{ +case 35:{ TclDateYear = TclDatepvt[-1].Number / 10000; TclDateMonth = (TclDatepvt[-1].Number % 10000)/100; TclDateDay = TclDatepvt[-1].Number % 100; @@ -1713,17 +1733,19 @@ case 33:{ TclDateMinutes = (TclDatepvt[-0].Number % 10000)/100; TclDateSeconds = TclDatepvt[-0].Number % 100; } break; -case 34:{ *TclDateRelPointer += TclDatepvt[-3].Number * TclDatepvt[-2].Number * TclDatepvt[-1].Number * TclDatepvt[-0].Number; } break; -case 35:{ *TclDateRelPointer += TclDatepvt[-2].Number * TclDatepvt[-1].Number * TclDatepvt[-0].Number; } break; -case 36:{ *TclDateRelPointer += TclDatepvt[-1].Number * TclDatepvt[-0].Number; } break; -case 37:{ TclDateval.Number = -1; } break; -case 38:{ TclDateval.Number = 1; } break; -case 39:{ TclDateval.Number = TclDatepvt[-0].Number; TclDateRelPointer = &TclDateRelSeconds; } break; -case 40:{ TclDateval.Number = TclDatepvt[-0].Number; TclDateRelPointer = &TclDateRelDay; } break; -case 41:{ TclDateval.Number = TclDatepvt[-0].Number; TclDateRelPointer = &TclDateRelMonth; } break; -case 42:{ TclDateval.Number = -1; } break; -case 43:{ TclDateval.Number = 1; } break; -case 44:{ +case 36:{ *TclDateRelPointer += TclDatepvt[-3].Number * TclDatepvt[-2].Number * TclDatepvt[-1].Number * TclDatepvt[-0].Number; } break; +case 37:{ *TclDateRelPointer += TclDatepvt[-2].Number * TclDatepvt[-1].Number * TclDatepvt[-0].Number; } break; +case 38:{ *TclDateRelPointer += TclDatepvt[-0].Number; } break; +case 39:{ *TclDateRelPointer += TclDatepvt[-1].Number * TclDatepvt[-0].Number; } break; +case 40:{ *TclDateRelPointer += TclDatepvt[-1].Number * TclDatepvt[-0].Number; } break; +case 41:{ TclDateval.Number = -1; } break; +case 42:{ TclDateval.Number = 1; } break; +case 43:{ TclDateval.Number = TclDatepvt[-0].Number; TclDateRelPointer = &TclDateRelSeconds; } break; +case 44:{ TclDateval.Number = TclDatepvt[-0].Number; TclDateRelPointer = &TclDateRelDay; } break; +case 45:{ TclDateval.Number = TclDatepvt[-0].Number; TclDateRelPointer = &TclDateRelMonth; } break; +case 46:{ TclDateval.Number = -1; } break; +case 47:{ TclDateval.Number = 1; } break; +case 48:{ if (TclDateHaveTime && TclDateHaveDate && !TclDateHaveRel) { TclDateYear = TclDatepvt[-0].Number; } else { @@ -1739,10 +1761,10 @@ case 44:{ TclDateMeridian = MER24; } } break; -case 45:{ +case 49:{ TclDateval.Meridian = MER24; } break; -case 46:{ +case 50:{ TclDateval.Meridian = TclDatepvt[-0].Meridian; } break; } diff --git a/generic/tclGetDate.y b/generic/tclGetDate.y index 510f164..ea66fd7 100644 --- a/generic/tclGetDate.y +++ b/generic/tclGetDate.y @@ -11,7 +11,7 @@ * See the file "license.terms" for information on usage and redistribution * of this file, and for a DISCLAIMER OF ALL WARRANTIES. * - * RCS: @(#) $Id: tclGetDate.y,v 1.11 2000/01/12 19:36:42 ericm Exp $ + * RCS: @(#) $Id: tclGetDate.y,v 1.12 2000/01/12 23:35:52 ericm Exp $ */ %{ @@ -138,11 +138,11 @@ yyparse _ANSI_ARGS_((void)); } %token tAGO tDAY tDAYZONE tID tMERIDIAN tMINUTE_UNIT tMONTH tMONTH_UNIT -%token tSEC_UNIT tSNUMBER tUNUMBER tZONE tEPOCH tDST tISOBASE tDAY_UNIT +%token tSEC_UNIT tSNUMBER tUNUMBER tZONE tEPOCH tDST tISOBASE tDAY_UNIT tNEXT %type <Number> tDAY tDAYZONE tMINUTE_UNIT tMONTH tMONTH_UNIT tDST %type <Number> tSEC_UNIT tSNUMBER tUNUMBER tZONE tISOBASE tDAY_UNIT -%type <Number> unit ago sign +%type <Number> unit ago sign tNEXT %type <Meridian> tMERIDIAN o_merid %% @@ -234,6 +234,14 @@ day : tDAY { yyDayOrdinal = $1; yyDayNumber = $2; } + | sign tUNUMBER tDAY { + yyDayOrdinal = $1 * $2; + yyDayNumber = $3; + } + | tNEXT tDAY { + yyDayOrdinal = 2; + yyDayNumber = $2; + } ; date : tUNUMBER '/' tUNUMBER { @@ -315,6 +323,8 @@ iso : tISOBASE tZONE tISOBASE { relspec : sign tUNUMBER unit ago { *yyRelPointer += $1 * $2 * $3 * $4; } | tUNUMBER unit ago { *yyRelPointer += $1 * $2 * $3; } + | tNEXT unit { *yyRelPointer += $2; } + | tNEXT tUNUMBER unit { *yyRelPointer += $2 * $3; } | unit ago { *yyRelPointer += $1 * $2; } ; sign : '-' { $$ = -1; } @@ -415,7 +425,7 @@ static TABLE OtherTable[] = { { "now", tSEC_UNIT, 0 }, { "last", tUNUMBER, -1 }, { "this", tSEC_UNIT, 0 }, - { "next", tUNUMBER, 1 }, + { "next", tNEXT, 1 }, #if 0 { "first", tUNUMBER, 1 }, { "second", tUNUMBER, 2 }, diff --git a/tests/clock.test b/tests/clock.test index fd97091..53eb63d 100644 --- a/tests/clock.test +++ b/tests/clock.test @@ -10,7 +10,7 @@ # See the file "license.terms" for information on usage and redistribution # of this file, and for a DISCLAIMER OF ALL WARRANTIES. # -# RCS: @(#) $Id: clock.test,v 1.6 2000/01/12 19:36:42 ericm Exp $ +# RCS: @(#) $Id: clock.test,v 1.7 2000/01/12 23:35:52 ericm Exp $ if {[lsearch [namespace children] ::tcltest] == -1} { package require tcltest @@ -257,6 +257,22 @@ test clock-4.32 {clock scan, relative minutes} { test clock-4.33 {clock scan, relative minutes} { clock scan "now -1 minute" -base 946627200 } 946627140 +test clock-4.34 {clock scan, day of week} { + clock format [clock scan "wednesday" -base [clock scan 20000112]] \ + -format {%b %d, %Y} +} "Jan 12, 2000" +test clock-4.35 {clock scan, next day of week} { + clock format [clock scan "next wednesday" -base [clock scan 20000112]] \ + -format {%b %d, %Y} +} "Jan 19, 2000" +test clock-4.36 {clock scan, day of week} { + clock format [clock scan "thursday" -base [clock scan 20000112]] \ + -format {%b %d, %Y} +} "Jan 13, 2000" +test clock-4.37 {clock scan, next day of week} { + clock format [clock scan "next thursday" -base [clock scan 20000112]] \ + -format {%b %d, %Y} +} "Jan 20, 2000" # clock seconds test clock-5.1 {clock seconds tests} { |