summaryrefslogtreecommitdiff
path: root/lib/date/delta/parser.ry
diff options
context:
space:
mode:
Diffstat (limited to 'lib/date/delta/parser.ry')
-rw-r--r--lib/date/delta/parser.ry85
1 files changed, 0 insertions, 85 deletions
diff --git a/lib/date/delta/parser.ry b/lib/date/delta/parser.ry
deleted file mode 100644
index 4de8aa1e46..0000000000
--- a/lib/date/delta/parser.ry
+++ /dev/null
@@ -1,85 +0,0 @@
-# parser.ry: Written by Tadayoshi Funaba 2006,2008-2010 -*- ruby -*-
-
-class Date::Delta::Parser
-
- prechigh
- nonassoc UNARY
- left '^'
- left '*' '/'
- left '+' ',' AND '-'
- preclow
-
- rule
-
- stmt : expr
- ;
-
- expr : time
- | iso
- | expr '+' expr {result += val[2]}
- | expr ',' expr {result += val[2]}
- | expr AND expr {result += val[2]}
- | expr '-' expr {result -= val[2]}
- | expr '*' DIGITS {result *= val[2]}
- | expr '/' DIGITS {result /= val[2]}
- | expr '^' DIGITS {result **= val[2]}
- | '-' expr =UNARY {result = -val[1]}
- | '+' expr =UNARY {result = +val[1]}
- | '(' expr ')' {result = val[1]}
- ;
-
- time : DIGITS unit {result = val[0] * val[1]}
- ;
-
- unit : {result = 1} | UNIT
- ;
-
- iso : DURATION
- ;
-
----- header ----
----- inner ----
-
- def lookup(str)
- t = str.downcase
- k = UNITS4KEY[t]
- return [:UNIT, k] if k
- return [:AND, nil] if t == 'and'
- return [:UNKNOWNWORD, nil]
- end
-
- def parse(str)
- @q = []
- until str.empty?
- case str
- when /\A\s+/
- when /\Ap\d+[ymdhsw]/i
- /\Ap(\d+y)?(\d+m)?(\d+d)?t?(\d+h)?(\d+m)?(\d+s)?(\d+w)?/i =~ str
- y, m, d, h, min, s, w =
- [$1, $2, $3, $4, $5, $6, $7].collect{|x| x.to_i}
- y *= UNITS4KEY['years']
- m *= UNITS4KEY['months']
- d *= UNITS4KEY['days']
- h *= UNITS4KEY['hours']
- min *= UNITS4KEY['minutes']
- s *= UNITS4KEY['seconds']
- w *= UNITS4KEY['weeks']
- @q.push [:DURATION, y + m + d + h + min + s + w]
- when /\A\d+/
- @q.push [:DIGITS, $&.to_i]
- when /\A[a-z]+/i
- @q.push lookup($&)
- when /\A.|\n/
- @q.push [$&, $&]
- end
- str = $'
- end
- @q.push [false, false]
- do_parse
- end
-
- def next_token
- @q.shift
- end
-
----- footer ----