Confusing behaviour after calculating a square root #28

This commit is contained in:
zosimadis 2018-01-06 13:21:48 +02:00
parent 67894925ad
commit 8833e0ed58
1 changed files with 11 additions and 3 deletions

View File

@ -92,6 +92,11 @@ class CalculatorImpl(calculator: Calculator, val context: Context) {
mBaseValue = getDisplayedNumberAsDouble() mBaseValue = getDisplayedNumberAsDouble()
} }
private fun handleRoot() {
mBaseValue = getDisplayedNumberAsDouble()
calculateResult()
}
private fun calculateResult() { private fun calculateResult() {
if (!mIsFirstOperation) { if (!mIsFirstOperation) {
updateFormula() updateFormula()
@ -107,15 +112,18 @@ class CalculatorImpl(calculator: Calculator, val context: Context) {
} }
fun handleOperation(operation: String) { fun handleOperation(operation: String) {
if (lastKey == DIGIT) if (lastKey == DIGIT && operation != ROOT)
handleResult() handleResult()
mResetValue = true mResetValue = true
lastKey = operation lastKey = operation
mLastOperation = operation mLastOperation = operation
if (operation == ROOT) if (operation == ROOT) {
calculateResult() handleRoot()
mResetValue = false
}
} }
fun handleClear() { fun handleClear() {