android_calculator-15: Add numeral systems
This commit is contained in:
		| @@ -14,6 +14,7 @@ import jscl.math.Generic; | ||||
| import org.jetbrains.annotations.NotNull; | ||||
| import org.jetbrains.annotations.Nullable; | ||||
| import org.solovyev.android.calculator.jscl.JsclOperation; | ||||
| import org.solovyev.android.calculator.model.CalculatorEngine; | ||||
| import org.solovyev.android.calculator.model.ParseException; | ||||
| import org.solovyev.android.calculator.model.TextProcessor; | ||||
| import org.solovyev.android.view.AutoResizeTextView; | ||||
| @@ -34,7 +35,7 @@ public class CalculatorDisplay extends AutoResizeTextView { | ||||
| 	private JsclOperation jsclOperation = JsclOperation.numeric; | ||||
|  | ||||
| 	@NotNull | ||||
| 	private final static TextProcessor<TextHighlighter.Result> textHighlighter = new TextHighlighter(Color.WHITE, true); | ||||
| 	private final static TextProcessor<TextHighlighter.Result> textHighlighter = new TextHighlighter(Color.WHITE, true, CalculatorEngine.instance.getEngine()); | ||||
|  | ||||
| 	@Nullable | ||||
| 	private Generic genericResult; | ||||
|   | ||||
| @@ -7,15 +7,16 @@ package org.solovyev.android.calculator; | ||||
|  | ||||
| import android.content.Context; | ||||
| import android.graphics.Color; | ||||
| import android.os.Build; | ||||
| import android.text.Html; | ||||
| import android.util.AttributeSet; | ||||
| import android.util.Log; | ||||
| import android.view.ContextMenu; | ||||
| import android.widget.EditText; | ||||
| import org.jetbrains.annotations.NotNull; | ||||
| import org.solovyev.android.calculator.model.CalculatorEngine; | ||||
| import org.solovyev.android.calculator.model.ParseException; | ||||
| import org.solovyev.android.calculator.model.TextProcessor; | ||||
| import org.solovyev.common.math.calculators.Calculator; | ||||
|  | ||||
| /** | ||||
|  * User: serso | ||||
| @@ -27,7 +28,7 @@ public class CalculatorEditor extends EditText { | ||||
| 	private boolean highlightText = true; | ||||
|  | ||||
| 	@NotNull | ||||
| 	private final static TextProcessor<TextHighlighter.Result> textHighlighter = new TextHighlighter(Color.WHITE, false); | ||||
| 	private final static TextProcessor<TextHighlighter.Result> textHighlighter = new TextHighlighter(Color.WHITE, false, CalculatorEngine.instance.getEngine()); | ||||
|  | ||||
| 	public CalculatorEditor(Context context) { | ||||
| 		super(context); | ||||
|   | ||||
| @@ -6,6 +6,7 @@ | ||||
|  | ||||
| package org.solovyev.android.calculator; | ||||
|  | ||||
| import jscl.MathContext; | ||||
| import org.jetbrains.annotations.NotNull; | ||||
| import org.solovyev.android.calculator.math.MathType; | ||||
| import org.solovyev.android.calculator.model.NumberBuilder; | ||||
| @@ -20,6 +21,9 @@ import org.solovyev.common.utils.MutableObject; | ||||
|  */ | ||||
| public class TextHighlighter implements TextProcessor<TextHighlighter.Result> { | ||||
|  | ||||
| 	@NotNull | ||||
| 	public final MathContext mathContext; | ||||
|  | ||||
| 	public static class Result implements CharSequence { | ||||
|  | ||||
| 		@NotNull | ||||
| @@ -63,9 +67,10 @@ public class TextHighlighter implements TextProcessor<TextHighlighter.Result> { | ||||
| 	private final int colorBlue; | ||||
| 	private final boolean simpleFormat; | ||||
|  | ||||
| 	public TextHighlighter(int baseColor, boolean simpleFormat) { | ||||
| 	public TextHighlighter(int baseColor, boolean simpleFormat, @NotNull MathContext mathContext) { | ||||
| 		this.color = baseColor; | ||||
| 		this.simpleFormat = simpleFormat; | ||||
| 		this.mathContext = mathContext; | ||||
| 		//this.colorRed = Color.red(baseColor); | ||||
| 		this.colorRed = (baseColor >> 16) & 0xFF; | ||||
| 		//this.colorGreen = Color.green(baseColor); | ||||
| @@ -86,7 +91,7 @@ public class TextHighlighter implements TextProcessor<TextHighlighter.Result> { | ||||
|  | ||||
| 		int numberOffset = 0; | ||||
|  | ||||
| 		final NumberBuilder numberBuilder = new NumberBuilder(simpleFormat); | ||||
| 		final NumberBuilder numberBuilder = new NumberBuilder(simpleFormat, mathContext.getNumeralBase()); | ||||
| 		for (int i = 0; i < text.length(); i++) { | ||||
| 			MathType.Result mathType = MathType.getType(text, i); | ||||
|  | ||||
|   | ||||
| @@ -16,7 +16,7 @@ import org.solovyev.android.calculator.model.TextProcessor; | ||||
|  | ||||
| public enum JsclOperation { | ||||
|  | ||||
| 	simplify(new FromJsclSimplifyTextProcessor()) { | ||||
| 	simplify(new FromJsclSimplifyTextProcessor(CalculatorEngine.instance.getEngine())) { | ||||
| 		@NotNull | ||||
| 		@Override | ||||
| 		public String evaluate(@NotNull String expression) throws ParseException { | ||||
|   | ||||
| @@ -20,7 +20,7 @@ import java.util.*; | ||||
|  | ||||
| public enum MathType { | ||||
|  | ||||
| /*	numeral_base(50, true, false) { | ||||
| 	numeral_base(50, true, false) { | ||||
|  | ||||
| 		private final List<String> tokens = new ArrayList<String>(10); | ||||
| 		{ | ||||
| @@ -37,7 +37,7 @@ public enum MathType { | ||||
| 		public List<String> getTokens() { | ||||
| 			return tokens; | ||||
| 		} | ||||
| 	},*/ | ||||
| 	}, | ||||
|  | ||||
| 	dot(200, true, true, ".") { | ||||
| 		@Override | ||||
|   | ||||
| @@ -338,7 +338,7 @@ public enum CalculatorEngine { | ||||
| 	} | ||||
|  | ||||
| 	public void setDefaultAngleUnits(@NotNull AngleUnit angleUnits) { | ||||
| 		getEngine().setDefaultAngleUnit(angleUnits); | ||||
| 		getEngine().setAngleUnits(angleUnits); | ||||
| 	} | ||||
|  | ||||
| 	// for tests only | ||||
|   | ||||
| @@ -1,5 +1,7 @@ | ||||
| package org.solovyev.android.calculator.model; | ||||
|  | ||||
| import jscl.MathContext; | ||||
| import jscl.MathEngine; | ||||
| import org.jetbrains.annotations.NotNull; | ||||
| import org.jetbrains.annotations.Nullable; | ||||
| import org.solovyev.android.calculator.math.MathType; | ||||
| @@ -14,12 +16,19 @@ import java.util.List; | ||||
|  */ | ||||
| public class FromJsclSimplifyTextProcessor implements TextProcessor<String> { | ||||
|  | ||||
| 	@NotNull | ||||
| 	private final MathContext mathContext; | ||||
|  | ||||
| 	public FromJsclSimplifyTextProcessor(@NotNull MathContext mathContext) { | ||||
| 		this.mathContext = mathContext; | ||||
| 	} | ||||
|  | ||||
| 	@NotNull | ||||
| 	@Override | ||||
| 	public String process(@NotNull String s) throws ParseException { | ||||
| 		final StringBuilder sb = new StringBuilder(); | ||||
|  | ||||
| 		final NumberBuilder numberBuilder = new NumberBuilder(true); | ||||
| 		final NumberBuilder numberBuilder = new NumberBuilder(true, mathContext.getNumeralBase()); | ||||
| 		for (int i = 0; i < s.length(); i++) { | ||||
| 			final MathType.Result mathTypeResult = MathType.getType(s, i); | ||||
|  | ||||
|   | ||||
| @@ -6,6 +6,7 @@ | ||||
|  | ||||
| package org.solovyev.android.calculator.model; | ||||
|  | ||||
| import jscl.NumeralBase; | ||||
| import org.jetbrains.annotations.NotNull; | ||||
| import org.jetbrains.annotations.Nullable; | ||||
| import org.solovyev.android.calculator.math.MathType; | ||||
| @@ -30,11 +31,16 @@ public class NumberBuilder { | ||||
|  | ||||
| 	private final boolean simpleFormat; | ||||
|  | ||||
| 	/*@Nullable | ||||
| 	@NotNull | ||||
| 	private final NumeralBase defaultNumeralBase; | ||||
|  | ||||
| 	@Nullable | ||||
| 	private NumeralBase nb; | ||||
| */ | ||||
| 	public NumberBuilder(boolean simpleFormat) { | ||||
|  | ||||
| 	public NumberBuilder(boolean simpleFormat, @NotNull NumeralBase defaultNumeralBase) { | ||||
| 		this.simpleFormat = simpleFormat; | ||||
| 		this.defaultNumeralBase = defaultNumeralBase; | ||||
| 		this.nb = defaultNumeralBase; | ||||
| 	} | ||||
|  | ||||
| 	@NotNull | ||||
| @@ -42,17 +48,17 @@ public class NumberBuilder { | ||||
| 		number = null; | ||||
|  | ||||
| 		final MathType.Result possibleResult; | ||||
| 		if ((CollectionsUtils.contains(mathTypeResult.getMathType(), MathType.digit, /*MathType.numeral_base,*/ MathType.dot, MathType.grouping_separator, MathType.power_10) || | ||||
| 		if ((CollectionsUtils.contains(mathTypeResult.getMathType(), MathType.digit, MathType.numeral_base, MathType.dot, MathType.grouping_separator, MathType.power_10) || | ||||
| 				isSignAfterE(mathTypeResult)) && numeralBaseCheck(mathTypeResult)) { | ||||
| 			if (numberBuilder == null) { | ||||
| 				numberBuilder = new StringBuilder(); | ||||
| 			} | ||||
|  | ||||
| 			/*if (mathTypeResult.getMathType() != MathType.numeral_base) {*/ | ||||
| 			if (mathTypeResult.getMathType() != MathType.numeral_base) { | ||||
| 				numberBuilder.append(mathTypeResult.getMatch()); | ||||
| 			/*} else { | ||||
| 			} else { | ||||
| 				nb = NumeralBase.getByPrefix(mathTypeResult.getMatch()); | ||||
| 			}*/ | ||||
| 			} | ||||
|  | ||||
| 			possibleResult = null; | ||||
| 		} else { | ||||
| @@ -63,7 +69,7 @@ public class NumberBuilder { | ||||
| 	} | ||||
|  | ||||
| 	private boolean numeralBaseCheck( @NotNull MathType.Result mathType ) { | ||||
| 		/*if ( mathType.getMathType() == MathType.digit ) { | ||||
| 		if ( mathType.getMathType() == MathType.digit ) { | ||||
| 			final Character ch = mathType.getMatch().charAt(0); | ||||
| 			if ( NumeralBase.hex.getAcceptableCharacters().contains(ch) && !NumeralBase.dec.getAcceptableCharacters().contains(ch) ) { | ||||
| 				if ( nb == NumeralBase.hex ) { | ||||
| @@ -76,8 +82,7 @@ public class NumberBuilder { | ||||
| 			} | ||||
| 		} else { | ||||
| 			return true; | ||||
| 		}*/ | ||||
| 		return true; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	private boolean isSignAfterE(@NotNull MathType.Result mathTypeResult) { | ||||
| @@ -113,7 +118,7 @@ public class NumberBuilder { | ||||
| 			} | ||||
|  | ||||
| 			numberBuilder = null; | ||||
| 			/*nb = null;*/ | ||||
| 			nb = defaultNumeralBase; | ||||
| 		} else { | ||||
| 			number = null; | ||||
| 		} | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Sergey Solovyev
					Sergey Solovyev