Added "encompass" key

This commit is contained in:
Sasha Koshka 2022-11-23 21:33:37 -05:00
parent 17c455b73d
commit 2f2c381d71

30
main.go
View File

@ -84,11 +84,16 @@ func onPress (button stone.Button, modifiers stone.Modifiers) {
redraw()
application.Draw()
case '\\':
insertOperation('?', false, true)
redraw()
application.Draw()
case
'+', '-', '*', '/', 'p', 'P', '%', '|', '~', '&', '^', 'm',
'l', 'r':
insertOperation(rune(button), modifiers.Alt)
insertOperation(rune(button), modifiers.Alt, false)
redraw()
application.Draw()
@ -244,9 +249,10 @@ func onPress (button stone.Button, modifiers stone.Modifiers) {
}
}
func insertOperation (symbol rune, swap bool) {
func insertOperation (symbol rune, swap, encompass bool) {
var opcode Opcode
switch (symbol) {
case '?': opcode = OpcodeUnknown
case '+': opcode = OpcodeAdd
case '-': opcode = OpcodeSubtract
case '*': opcode = OpcodeMultiply
@ -263,6 +269,23 @@ func insertOperation (symbol rune, swap bool) {
case 'm': opcode = OpcodeMean
}
newExpression := Operation { opcode: opcode, floating: showFloat }
if encompass {
if selectedExpression == nil { return }
parent := selectedExpression.Parent()
newExpression.Adopt(selectedExpression)
if parent == nil {
expressionRoot = &newExpression
} else {
parent.Swap(selectedExpression, &newExpression)
}
selectedExpression = &newExpression
return
}
operation, isOperation := selectedExpression.(*Operation)
if isOperation {
if operation.opcode == OpcodeUnknown || swap {
@ -271,8 +294,7 @@ func insertOperation (symbol rune, swap bool) {
}
}
newExpression := &Operation { opcode: opcode, floating: showFloat }
insertGeneric(newExpression, swap, false, true)
insertGeneric(&newExpression, swap, false, true)
}
func insertNumber (value int64, swap, before bool) {