Merge pull request #53 from ensozos/Issue#28

Confusing behaviour after calculating a square root #28
This commit is contained in:
Tibor Kaputa
2018-01-06 13:03:14 +01:00
committed by GitHub

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() {