/* Serene --- Yet an other Lisp Copyright (c) 2020 Sameer Rahmani This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 2 of the License. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . */ package core import ( "errors" "fmt" "serene-lang.org/bootstrap/pkg/ast" ) type ICallable interface { Apply(rt *Runtime, scope IScope, args *List) (IExpr, error) } type Function struct { Node name string scope IScope params IColl body *Block } func (f *Function) GetType() ast.NodeType { return ast.Fn } func (f *Function) String() string { return fmt.Sprintf(" values.Count() { return nil, errors.New("'binding' and 'valuse' size don't match") } binds := bindings.ToSlice() exprs := values.ToSlice() for i := 0; i < len(binds); i += 1 { if binds[i].GetType() == ast.Symbol && binds[i].(*Symbol).IsRestable() { scope.Insert(binds[i+1].(*Symbol).GetName(), MakeList(exprs[i:]), false) break } else { scope.Insert(binds[i].(*Symbol).GetName(), exprs[i], false) } } return scope, nil }