SHS/ast/func_table.go

67 lines
1.6 KiB
Go
Raw Normal View History

2019-11-29 12:57:03 -08:00
/* SHS: Syntactically Homogeneous Shell
* Copyright (C) 2019 Aidan Hahn
*
* 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 3 of the License, or
* (at your option) any later version.
*
* 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 <https://www.gnu.org/licenses/>.
*/
2020-06-20 21:38:46 -07:00
package ast
type Operation func(*Token) *Token
type Function struct {
function Operation
timesCalled int
args int // TODO: Make this a list of expected types (TAGs)
}
type FuncTable map[string]*Function
// TODO: Currently only checks arg list length
2020-06-20 22:56:22 -07:00
func (f Function) ParseFunction(args *Token) bool {
// HANDLE EXEC
2020-06-20 22:56:22 -07:00
if f.args < 0 {
return true
}
2020-06-20 22:56:22 -07:00
i := f.args
for iter := args; iter != nil; iter = iter.Next {
i -= 1
}
if i != 0 {
// TODO: log error here
return false
}
return true
}
2020-06-20 22:56:22 -07:00
func (f Function) CallFunction(args *Token) *Token {
if !f.ParseFunction(args) {
return nil
}
f.timesCalled += 1
return f.function(args)
}
2020-06-20 22:56:22 -07:00
func (table FuncTable) GetFunction(arg string) *Function {
target, ok := table[arg]
if !ok {
return nil
}
return target
}