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

Interpreter #4

Merged
merged 37 commits into from
Aug 1, 2024
Merged
Changes from 1 commit
Commits
Show all changes
37 commits
Select commit Hold shift + click to select a range
bacbb78
initial draft
ascandone Jul 22, 2024
7499d3f
handling vars
ascandone Jul 22, 2024
b9ed59d
impl inorder src
ascandone Jul 23, 2024
a9a3528
WIP
ascandone Jul 23, 2024
d7b55c2
Merge branch 'main' into experiment/interpreter
ascandone Jul 29, 2024
b966ba4
implemented allotted destination
ascandone Jul 29, 2024
d937159
implemented remaining in allotment
ascandone Jul 29, 2024
a401e2c
added todo tests
ascandone Jul 29, 2024
2d007db
impl new test
ascandone Jul 29, 2024
b790501
impl send from world
ascandone Jul 29, 2024
9b393bf
add new test
ascandone Jul 29, 2024
b707344
add new test
ascandone Jul 29, 2024
2cfac3c
impl new test
ascandone Jul 29, 2024
6012735
refactored literals evaluation
ascandone Jul 29, 2024
0d290ac
added track balance tests
ascandone Jul 30, 2024
0ba27a4
Merge branch 'main' into experiment/interpreter
ascandone Jul 30, 2024
ad3947d
implemented source allotment
ascandone Jul 30, 2024
a4dc47e
refactored allotment code
ascandone Jul 30, 2024
dbbdd91
refactor
ascandone Jul 30, 2024
b196366
cleaned up code
ascandone Jul 30, 2024
4a208b7
implemented cap source
ascandone Jul 30, 2024
f2a9f33
minor
ascandone Jul 30, 2024
99ee840
impl inorder dest
ascandone Jul 30, 2024
f0611fb
unskipped test
ascandone Jul 31, 2024
1d2e6ba
impl unbounded overdraft
ascandone Jul 31, 2024
4d8f0e6
refactor
ascandone Jul 31, 2024
88a72f2
minor
ascandone Jul 31, 2024
82856bd
better error handling
ascandone Jul 31, 2024
d928731
better error handling
ascandone Jul 31, 2024
7e53c9d
better err handling
ascandone Jul 31, 2024
e90754c
defined more runtime errs
ascandone Jul 31, 2024
8bb68ff
added more runtime errs
ascandone Aug 1, 2024
2b1f088
better args parsing
ascandone Aug 1, 2024
9c60aa7
better errors
ascandone Aug 1, 2024
0a0a4d2
quick and dirty run cli
ascandone Aug 1, 2024
e64eb15
handling run flags
ascandone Aug 1, 2024
0d6b63b
printing postings and data
ascandone Aug 1, 2024
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
Prev Previous commit
Next Next commit
refactor
ascandone committed Jul 31, 2024
commit 4d8f0e6936cab0cbeb8c4e695d5afa61f2ffb494
17 changes: 8 additions & 9 deletions interpreter/interpreter.go
Original file line number Diff line number Diff line change
@@ -214,7 +214,7 @@ func (st *programState) evaluateLit(literal parser.Literal) (Value, error) {
return nil, err
}

return Monetary{Asset: *asset, Amount: *amount}, nil
return Monetary{Asset: Asset(*asset), Amount: MonetaryInt(*amount)}, nil

case *parser.VariableLiteral:
value, ok := st.Vars[literal.Name]
@@ -573,15 +573,14 @@ func (s *programState) makeAllotment(monetary int64, items []parser.AllotmentVal
totalAllotment.Add(totalAllotment, rat)
allotments = append(allotments, *rat)
case *parser.VariableLiteral:
portion, err := evaluateLitExpecting(s, allotment, expectPortion)
rat, err := evaluateLitExpecting(s, allotment, expectPortion)
if err != nil {
// TODO proper error handling
panic(err)
}

rat := big.Rat(*portion)
totalAllotment.Add(totalAllotment, &rat)
allotments = append(allotments, rat)
totalAllotment.Add(totalAllotment, rat)
allotments = append(allotments, *rat)

case *parser.RemainingAllotment:
remainingAllotmentIndex = i
@@ -643,8 +642,8 @@ func meta(
}

// body
accountMeta := s.Meta[account.String()]
value, ok := accountMeta[string(*key)]
accountMeta := s.Meta[*account]
value, ok := accountMeta[*key]

if !ok {
// TODO err
@@ -673,7 +672,7 @@ func balance(
}

// body
balance := s.getBalance(string(*account), string(*asset))
balance := s.getBalance(*account, *asset)
var balanceCopy big.Int
balanceCopy.Set(balance)

@@ -696,6 +695,6 @@ func setTxMeta(st *programState, args []Value) error {
}

meta := args[1]
st.TxMeta[string(*k)] = meta
st.TxMeta[*k] = meta
return nil
}
20 changes: 10 additions & 10 deletions interpreter/value.go
Original file line number Diff line number Diff line change
@@ -45,50 +45,50 @@ func expectMonetary(v Value) (*Monetary, error) {
}
}

func expectNumber(v Value) (*MonetaryInt, error) {
func expectNumber(v Value) (*big.Int, error) {
switch v := v.(type) {
case MonetaryInt:
return &v, nil
return (*big.Int)(&v), nil

default:
return nil, TypeError{Expected: analysis.TypeNumber, Value: v}
}
}

func expectString(v Value) (*String, error) {
func expectString(v Value) (*string, error) {
switch v := v.(type) {
case String:
return &v, nil
return (*string)(&v), nil

default:
return nil, TypeError{Expected: analysis.TypeString, Value: v}
}
}

func expectAsset(v Value) (*Asset, error) {
func expectAsset(v Value) (*string, error) {
switch v := v.(type) {
case Asset:
return &v, nil
return (*string)(&v), nil

default:
return nil, TypeError{Expected: analysis.TypeAsset, Value: v}
}
}

func expectAccount(v Value) (*AccountAddress, error) {
func expectAccount(v Value) (*string, error) {
switch v := v.(type) {
case AccountAddress:
return &v, nil
return (*string)(&v), nil

default:
return nil, TypeError{Expected: analysis.TypeAccount, Value: v}
}
}

func expectPortion(v Value) (*Portion, error) {
func expectPortion(v Value) (*big.Rat, error) {
switch v := v.(type) {
case Portion:
return &v, nil
return (*big.Rat)(&v), nil

default:
return nil, TypeError{Expected: analysis.TypePortion, Value: v}