Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Free up curly brace syntax. #8578

Merged
merged 7 commits into from
Oct 9, 2014
Merged
Show file tree
Hide file tree
Changes from 5 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion base/LineEdit.jl
Original file line number Diff line number Diff line change
Expand Up @@ -834,7 +834,7 @@ function keymap{D<:Dict}(keymaps::Array{D})
end

const escape_defaults = merge!(
{char(i) => nothing for i=[1:26, 28:31]}, # Ignore control characters by default
AnyDict([char(i) => nothing for i=[1:26, 28:31]]), # Ignore control characters by default
AnyDict( # And ignore other escape sequences by default
"\e*" => nothing,
"\e[*" => nothing,
Expand Down
2 changes: 1 addition & 1 deletion base/REPL.jl
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,7 @@ function eval_user_input(ast::ANY, backend::REPLBackend)
ans = backend.ans
# note: value wrapped in a non-syntax value to avoid evaluating
# possibly-invalid syntax (issue #6763).
eval(Main, :(ans = $({ans})[1]))
eval(Main, :(ans = $(Any[ans])[1]))
value = eval(Main, ast)
backend.ans = value
put!(backend.response_channel, (value, nothing))
Expand Down
2 changes: 1 addition & 1 deletion base/abstractarray.jl
Original file line number Diff line number Diff line change
Expand Up @@ -1182,7 +1182,7 @@ end
##
# generic map on any iterator
function map(f::Callable, iters...)
result = {}
result = []
len = length(iters)
states = [start(iters[idx]) for idx in 1:len]
nxtvals = cell(len)
Expand Down
2 changes: 1 addition & 1 deletion base/base.jl
Original file line number Diff line number Diff line change
Expand Up @@ -175,7 +175,7 @@ function length_checked_equal(args...)
n
end

map(f::Callable, a::Array{Any,1}) = { f(a[i]) for i=1:length(a) }
map(f::Callable, a::Array{Any,1}) = Any[ f(a[i]) for i=1:length(a) ]

macro thunk(ex); :(()->$(esc(ex))); end
macro L_str(s); s; end
Expand Down
4 changes: 2 additions & 2 deletions base/client.jl
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,7 @@ function repl_hook(input::String)
macroexpand(Expr(:macrocall,symbol("@cmd"),input)))
end

display_error(er) = display_error(er, {})
display_error(er) = display_error(er, [])
function display_error(er, bt)
with_output_color(:red, STDERR) do io
print(io, "ERROR: ")
Expand Down Expand Up @@ -420,7 +420,7 @@ function _start()
ccall(:uv_atexit_hook, Void, ())
end

const atexit_hooks = {}
const atexit_hooks = []

atexit(f::Function) = (unshift!(atexit_hooks, f); nothing)

Expand Down
2 changes: 1 addition & 1 deletion base/combinatorics.jl
Original file line number Diff line number Diff line change
Expand Up @@ -463,7 +463,7 @@ function nextsetpartition(s::AbstractVector, a, b, n, m)
filter!(x->!isempty(x), temp)
end

if isempty(s); return ({s}, ([1], Int[], n, 1)); end
if isempty(s); return ([s], ([1], Int[], n, 1)); end

part = makeparts(s,a,m)

Expand Down
2 changes: 1 addition & 1 deletion base/constants.jl
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ convert{T<:Integer}(::Type{Rational{T}}, x::MathConst) = convert(Rational{T}, fl
hash(x::MathConst, h::Uint) = hash(object_id(x), h)

-(x::MathConst) = -float64(x)
for op in {:+, :-, :*, :/, :^}
for op in Symbol[:+, :-, :*, :/, :^]
@eval $op(x::MathConst, y::MathConst) = $op(float64(x),float64(y))
end

Expand Down
4 changes: 2 additions & 2 deletions base/darray.jl
Original file line number Diff line number Diff line change
Expand Up @@ -272,7 +272,7 @@ function setindex!(a::Array, s::SubDArray, I::UnitRange{Int}...)
offs = [isa(J[i],Int) ? J[i]-1 : first(J[i])-1 for i=1:n]
@sync begin
for i = 1:length(d.chunks)
K_c = {d.indexes[i]...}
K_c = Any[d.indexes[i]...]
K = [ intersect(J[j],K_c[j]) for j=1:n ]
if !any(isempty, K)
idxs = [ I[j][K[j]-offs[j]] for j=1:n ]
Expand Down Expand Up @@ -302,7 +302,7 @@ map(f::Callable, d::DArray) = DArray(I->map(f, localpart(d)), d)

reduce(f::Function, d::DArray) =
mapreduce(fetch, f,
{ @spawnat p reduce(f, localpart(d)) for p in procs(d) })
Any[ @spawnat p reduce(f, localpart(d)) for p in procs(d) ])


function map!(f::Callable, d::DArray)
Expand Down
4 changes: 2 additions & 2 deletions base/dates/io.jl
Original file line number Diff line number Diff line change
Expand Up @@ -62,7 +62,7 @@ duplicates(slots) = any(map(x->count(y->x.period==y.period,slots),slots) .> 1)

function DateFormat(f::String,locale::String="english")
slots = Slot[]
trans = {}
trans = []
begtran = match(r"^.*?(?=[ymuUdHMSsEe])",f).match
ss = split(f,r"^.*?(?=[ymuUdHMSsEe])")
s = split(begtran == "" ? ss[1] : ss[2],r"[^ymuUdHMSsEe]+|(?<=([ymuUdHMSsEe])(?!\1))")
Expand Down Expand Up @@ -182,4 +182,4 @@ function format(y::AbstractArray{Date},df::DateFormat=ISODateFormat)
end
function format(y::AbstractArray{DateTime},df::DateFormat=ISODateTimeFormat)
return reshape([Dates.format(y[i],df) for i in 1:length(y)], size(y))
end
end
2 changes: 1 addition & 1 deletion base/deprecated.jl
Original file line number Diff line number Diff line change
Expand Up @@ -108,7 +108,7 @@ eval(Sys, :(@deprecate shlib_list dllist))
@deprecate put put!
@deprecate take take!

@deprecate Set(a, b...) Set({a, b...})
@deprecate Set(a, b...) Set([a, b...])
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Needs Any to avoid concatenation.

# for a bit of backwards compatibility
IntSet(xs::Integer...) = (s=IntSet(); for a in xs; push!(s,a); end; s)
Set{T<:Number}(xs::T...) = Set{T}(xs)
Expand Down
2 changes: 1 addition & 1 deletion base/expr.jl
Original file line number Diff line number Diff line change
Expand Up @@ -72,7 +72,7 @@ _inline(arg) = arg

## some macro utilities ##

find_vars(e) = find_vars(e, {})
find_vars(e) = find_vars(e, [])
function find_vars(e, lst)
if isa(e,Symbol)
if current_module()===Main && isdefined(e)
Expand Down
6 changes: 3 additions & 3 deletions base/help.jl
Original file line number Diff line number Diff line change
Expand Up @@ -48,11 +48,11 @@ function init_help()
mfunc = func
end
if !haskey(FUNCTION_DICT, mfunc)
FUNCTION_DICT[mfunc] = {}
FUNCTION_DICT[mfunc] = []
end
push!(FUNCTION_DICT[mfunc], desc)
if !haskey(MODULE_DICT, func)
MODULE_DICT[func] = {}
MODULE_DICT[func] = []
end
if !in(mod, MODULE_DICT[func])
push!(MODULE_DICT[func], mod)
Expand Down Expand Up @@ -94,7 +94,7 @@ function help(io::IO, fname::String, obj=0)
found = true
elseif haskey(MODULE_DICT, fname)
allmods = MODULE_DICT[fname]
alldesc = {}
alldesc = []
for mod in allmods
mfname = isempty(mod) ? fname : mod * "." * fname
if isgeneric(obj)
Expand Down
70 changes: 36 additions & 34 deletions base/inference.jl
Original file line number Diff line number Diff line change
Expand Up @@ -367,7 +367,7 @@ const getfield_tfunc = function (A, s0, name)
return R
else
return limit_type_depth(R, 0, true,
filter!(x->isa(x,TypeVar), {s.parameters...}))
filter!(x->isa(x,TypeVar), Any[s.parameters...]))
end
end
end
Expand Down Expand Up @@ -1353,7 +1353,7 @@ function typeinf(linfo::LambdaStaticData,atypes::Tuple,sparams::Tuple, def, cop)
rec = false
toprec = false

s = { () for i=1:n }
s = Any[ () for i=1:n ]
# initial types
s[1] = ObjectIdDict()
for v in vars
Expand Down Expand Up @@ -1412,7 +1412,7 @@ function typeinf(linfo::LambdaStaticData,atypes::Tuple,sparams::Tuple, def, cop)

# exception handlers
cur_hand = ()
handler_at = { () for i=1:n }
handler_at = Any[ () for i=1:n ]

push!(W,1) # initial set of pc

Expand Down Expand Up @@ -1573,7 +1573,7 @@ function typeinf(linfo::LambdaStaticData,atypes::Tuple,sparams::Tuple, def, cop)

if !redo
if is(def.tfunc,())
def.tfunc = {}
def.tfunc = []
end
tfarr = def.tfunc::Array{Any,1}
idx = -1
Expand Down Expand Up @@ -1698,7 +1698,7 @@ function type_annotate(ast::Expr, states::Array{Any,1}, sv::ANY, rettype::ANY,
for arg in args
decls[arg] = states[1][arg]
end
closures = {}
closures = []
body = ast.args[3].args::Array{Any,1}
for i=1:length(body)
st_i = states[i]
Expand Down Expand Up @@ -1916,7 +1916,7 @@ function exprtype(x::ANY)
end

function without_linenums(a::Array{Any,1})
l = {}
l = []
for x in a
if (isa(x,Expr) && is(x.head,:line)) || isa(x,LineNumberNode)
else
Expand All @@ -1926,9 +1926,11 @@ function without_linenums(a::Array{Any,1})
l
end

# known affect-free calls (also effect-free)
const _pure_builtins = Any[tuple, tupleref, tuplelen, fieldtype, apply_type, is, isa, typeof, typeassert]

const _pure_builtins = {tuple, tupleref, tuplelen, fieldtype, apply_type, is, isa, typeof, typeassert} # known affect-free calls (also effect-free)
const _pure_builtins_volatile = {getfield, arrayref} # known effect-free calls (might not be affect-free)
# known effect-free calls (might not be affect-free)
const _pure_builtins_volatile = Any[getfield, arrayref]

function is_pure_builtin(f)
if contains_is(_pure_builtins, f)
Expand Down Expand Up @@ -2128,7 +2130,7 @@ function inlineable(f, e::Expr, atypes, sv, enclosing_ast)

sp = meth[2]::Tuple
sp = tuple(sp..., linfo.sparams...)
spvals = { sp[i] for i in 2:2:length(sp) }
spvals = Any[ sp[i] for i in 2:2:length(sp) ]
for i=1:length(spvals)
if isa(spvals[i], TypeVar)
return NF
Expand Down Expand Up @@ -2185,27 +2187,27 @@ function inlineable(f, e::Expr, atypes, sv, enclosing_ast)
numarg = length(argexprs)
newnames = unique_names(ast,numarg)
sp = ()
spvals = {}
spvals = []
meth = (methargs, sp)
locals = {}
locals = []
newcall = Expr(:call, e.args[1])
newcall.typ = ty
for i = 1:numarg
name = newnames[i]
argtype = exprtype(argexprs[i])
argtype = typeintersect(argtype,Any) # remove Undef
push!(locals, {name,argtype,0})
push!(locals, Any[name,argtype,0])
push!(newcall.args, argtype===Any ? name : SymbolNode(name, argtype))
end
body.args = {Expr(:return, newcall)}
ast = Expr(:lambda, newnames, {{}, locals, {}}, body)
body.args = Any[Expr(:return, newcall)]
ast = Expr(:lambda, newnames, Any[[], locals, []], body)
need_mod_annotate = false
else
return NF
end
end

spnames = { sp[i].name for i=1:2:length(sp) }
spnames = Any[ sp[i].name for i=1:2:length(sp) ]
enc_vinflist = enclosing_ast.args[2][2]::Array{Any,1}
enc_locllist = enclosing_ast.args[2][1]::Array{Any,1}
locllist = ast.args[2][1]::Array{Any,1}
Expand Down Expand Up @@ -2237,7 +2239,7 @@ function inlineable(f, e::Expr, atypes, sv, enclosing_ast)
for vi in vinflist
if vi[1] === vaname && vi[2] != 0
islocal = true
push!(enc_vinflist, {vnew, vi[2], vi[3]})
push!(enc_vinflist, Any[vnew, vi[2], vi[3]])
end
end
if islocal
Expand All @@ -2248,7 +2250,7 @@ function inlineable(f, e::Expr, atypes, sv, enclosing_ast)
else
# construct tuple-forming expression for argument tail
vararg = mk_tuplecall(argexprs[na:end])
argexprs = {argexprs[1:(na-1)]..., vararg}
argexprs = Any[argexprs[1:(na-1)]..., vararg]
isva = true
end
elseif na != length(argexprs)
Expand All @@ -2275,7 +2277,7 @@ function inlineable(f, e::Expr, atypes, sv, enclosing_ast)
push!(enc_locllist, vnew)
for vi in vinflist
if vi[1] === localval
push!(enc_vinflist, {vnew, vi[2], vi[3]})
push!(enc_vinflist, Any[vnew, vi[2], vi[3]])
end
end
end
Expand All @@ -2294,7 +2296,7 @@ function inlineable(f, e::Expr, atypes, sv, enclosing_ast)
end

# see if each argument occurs only once in the body expression
stmts = {}
stmts = []
stmts_free = true # true = all entries of stmts are effect_free

# when 1 method matches the inferred types, there is still a chance
Expand Down Expand Up @@ -2562,7 +2564,7 @@ function inlining_pass(e::Expr, sv, ast)
return (e,())
end
arg1 = eargs[1]
stmts = {}
stmts = []
if e.head === :body
i = 1
while i <= length(eargs)
Expand Down Expand Up @@ -2657,10 +2659,10 @@ function inlining_pass(e::Expr, sv, ast)
if isa(a1,basenumtype) || ((isa(a1,Symbol) || isa(a1,SymbolNode)) &&
exprtype(a1) <: basenumtype)
if e.args[3]==2
e.args = {TopNode(:*), a1, a1}
e.args = Any[TopNode(:*), a1, a1]
f = *
elseif e.args[3]==3
e.args = {TopNode(:*), a1, a1, a1}
e.args = Any[TopNode(:*), a1, a1, a1]
f = *
end
end
Expand Down Expand Up @@ -2701,16 +2703,16 @@ function inlining_pass(e::Expr, sv, ast)
# apply(f,tuple(x,y,...)) => f(x,y,...)
newargs[i-2] = aarg.args[2:end]
elseif isa(aarg, Tuple)
newargs[i-2] = { QuoteNode(x) for x in aarg }
newargs[i-2] = Any[ QuoteNode(x) for x in aarg ]
elseif isa(t,Tuple) && !isvatuple(t) && effect_free(aarg,sv,true)
# apply(f,t::(x,y)) => f(t[1],t[2])
newargs[i-2] = { mk_tupleref(aarg,j,t[j]) for j=1:length(t) }
newargs[i-2] = Any[ mk_tupleref(aarg,j,t[j]) for j=1:length(t) ]
else
# not all args expandable
return (e,stmts)
end
end
e.args = [{e.args[2]}, newargs...]
e.args = [Any[e.args[2]], newargs...]

# now try to inline the simplified call

Expand All @@ -2729,17 +2731,17 @@ function inlining_pass(e::Expr, sv, ast)
end

function add_variable(ast, name, typ, is_sa)
vinf = {name,typ,2+16*is_sa}
vinf = Any[name, typ, 2+16*is_sa]
locllist = ast.args[2][1]::Array{Any,1}
vinflist = ast.args[2][2]::Array{Any,1}
push!(locllist, name)
push!(vinflist, vinf)
end

const some_names = {:_var0, :_var1, :_var2, :_var3, :_var4, :_var5, :_var6,
:_var7, :_var8, :_var9, :_var10, :_var11, :_var12,
:_var13, :_var14, :_var15, :_var16, :_var17, :_var18,
:_var19, :_var20, :_var21, :_var22, :_var23, :_var24}
const some_names = Symbol[:_var0, :_var1, :_var2, :_var3, :_var4, :_var5, :_var6,
:_var7, :_var8, :_var9, :_var10, :_var11, :_var12,
:_var13, :_var14, :_var15, :_var16, :_var17, :_var18,
:_var19, :_var20, :_var21, :_var22, :_var23, :_var24]
function contains_is1(vinflist::Array{Any,1}, x::Symbol)
for y in vinflist
if is(y[1],x)
Expand Down Expand Up @@ -2779,7 +2781,7 @@ function unique_name(ast1, ast2)
end

function unique_names(ast, n)
ns = {}
ns = []
locllist = ast.args[2][2]::Array{Any,1}
for g in some_names
if !contains_is1(locllist, g)
Expand Down Expand Up @@ -2856,7 +2858,7 @@ function remove_redundant_temp_vars(ast, sa)
# everywhere later in the function

delete_var!(ast, v)
sym_replace(ast.args[3], {v}, {}, {init}, {})
sym_replace(ast.args[3], [v], [], [init], [])
end
end
end
Expand Down Expand Up @@ -3056,7 +3058,7 @@ function replace_tupleref!(ast, e::ANY, tupname, vals, sv, i0)
end

function code_typed(f::Callable, types::(Type...))
asts = {}
asts = []
for x in _methods(f,types,-1)
linfo = func_for_method(x[3],types)
(tree, ty) = typeinf(linfo, x[1], x[2])
Expand All @@ -3070,7 +3072,7 @@ function code_typed(f::Callable, types::(Type...))
end

function return_types(f::Callable, types)
rt = {}
rt = []
for x in _methods(f,types,-1)
linfo = func_for_method(x[3],types)
(tree, ty) = typeinf(linfo, x[1], x[2])
Expand Down
Loading