way better lex function
This commit is contained in:
parent
6f7adc0789
commit
65cecb3647
7 changed files with 60 additions and 37 deletions
22
stack.go
Normal file
22
stack.go
Normal file
|
|
@ -0,0 +1,22 @@
|
|||
package shsh
|
||||
|
||||
type TokenStack struct {
|
||||
buffer []*Token
|
||||
capacity int
|
||||
}
|
||||
|
||||
func (s *TokenStack) Push(v *Token) {
|
||||
s.capacity++
|
||||
s.buffer = append(s.buffer, v)
|
||||
}
|
||||
|
||||
func (s *TokenStack) Pop() *Token {
|
||||
if s.capacity <= 0 {
|
||||
return nil
|
||||
}
|
||||
|
||||
s.capacity--
|
||||
res := s.buffer[len(s.buffer) - 1]
|
||||
s.buffer = s.buffer[:len(s.buffer) - 1]
|
||||
return res
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue