Skip to content

Commit

Permalink
add deprecation warnings for {} syntax
Browse files Browse the repository at this point in the history
  • Loading branch information
jakebolewski committed Oct 7, 2014
1 parent 6c52fb6 commit ccbc806
Showing 1 changed file with 54 additions and 8 deletions.
62 changes: 54 additions & 8 deletions src/julia-parser.scm
Original file line number Diff line number Diff line change
Expand Up @@ -1427,7 +1427,7 @@
(loop lst nxt)
(let ((params (parse-arglist s closer)))
`(vcat ,@params ,@lst ,nxt))))
((#\])
((#\] #\})
(error (string "unexpected \"" t "\"")))
(else
(error "missing separator in array expression")))))))
Expand Down Expand Up @@ -1508,11 +1508,8 @@
(take-token s)
(parse-dict-comprehension s first closer))
(else
(if (eqv? closer #\})
(syntax-deprecation-warning s "{a=>b, ...}" "Dict{Any,Any}(a=>b, ...)")
(or
(and (pair? isdict) (car isdict))
(syntax-deprecation-warning s "[a=>b, ...]" "Dict(a=>b, ...)")))
(if (and (pair? isdict) (car isdict))
(syntax-deprecation-warning s "[a=>b, ...]" "Dict(a=>b, ...)"))
(parse-dict s first closer)))
(case (peek-token s)
((#\,)
Expand Down Expand Up @@ -1783,9 +1780,58 @@
(else
(error "missing separator in tuple")))))))))

;; TODO this awaits a decision on {} syntax in 0.4
;; cell expression
((eqv? t #\{ )
(error "{} syntax for Any arrays / dicts has been removed in 0.4dev"))
(take-token s)
(if (eqv? (require-token s) #\})
(begin
(syntax-deprecation-warning s "{}" "[]")
(take-token s)
'(cell1d))
(let ((vex (parse-cat s #\})))
(if (null? vex)
(begin
(syntax-deprecation-warning s "{}" "[]")
'(cell1d))
(case (car vex)
((comprehension)
(syntax-deprecation-warning s "{a for a in b}" "Any[a for a in b]")
`(typed_comprehension (top Any) ,@(cdr vex)))
((dict_comprehension)
(syntax-deprecation-warning s "{a=>b for (a,b) in c}" "Dict{Any,Any}([a=>b for (a,b) in c])")
`(typed_dict_comprehension (=> (top Any) (top Any)) ,@(cdr vex)))
((dict)
(syntax-deprecation-warning s "{a=>b, ...}" "Dict{Any,Any}(a=>b, ...)")
`(typed_dict (=> (top Any) (top Any)) ,@(cdr vex)))
((hcat)
(syntax-deprecation-warning s "{a b}" "Any[a b]")
`(cell2d 1 ,(length (cdr vex)) ,@(cdr vex)))
(else ; (vcat ...)
(if (and (pair? (cadr vex)) (eq? (caadr vex) 'row))
(let ((nr (length (cdr vex)))
(nc (length (cdadr vex))))
;; make sure all rows are the same length
(if (not (every
(lambda (x)
(and (pair? x)
(eq? (car x) 'row)
(length= (cdr x) nc)))
(cddr vex)))
(error "inconsistent shape in cell expression"))
(begin
(syntax-deprecation-warning s "{[a,b] [c d]}" "Any[[a,b] [c,d]]"))
`(cell2d ,nr ,nc
,@(apply append
;; transpose to storage order
(apply map list
(map cdr (cdr vex))))))
(if (any (lambda (x) (and (pair? x)
(eq? (car x) 'row)))
(cddr vex))
(error "inconsistent shape in cell expression")
(begin
(syntax-deprecation-warning s "{a,b,c...}" "Any[a,b,c]")
`(cell1d ,@(cdr vex)))))))))))

;; cat expression
((eqv? t #\[ )
Expand Down

0 comments on commit ccbc806

Please sign in to comment.