mirror of
https://github.com/songoda/SongodaCore.git
synced 2024-11-30 14:03:23 +01:00
Merge branch 'development'
This commit is contained in:
commit
1acce7d352
@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>com.songoda</groupId>
|
<groupId>com.songoda</groupId>
|
||||||
<artifactId>SongodaCore-Modules</artifactId>
|
<artifactId>SongodaCore-Modules</artifactId>
|
||||||
<version>2.4.56</version>
|
<version>2.4.57</version>
|
||||||
<relativePath>../</relativePath>
|
<relativePath>../</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>com.songoda</groupId>
|
<groupId>com.songoda</groupId>
|
||||||
<artifactId>SongodaCore-Modules</artifactId>
|
<artifactId>SongodaCore-Modules</artifactId>
|
||||||
<version>2.4.56</version>
|
<version>2.4.57</version>
|
||||||
<relativePath>../</relativePath>
|
<relativePath>../</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
@ -56,7 +56,7 @@ public class SongodaCore {
|
|||||||
/**
|
/**
|
||||||
* This has been added as of Rev 6
|
* This has been added as of Rev 6
|
||||||
*/
|
*/
|
||||||
private final static String coreVersion = "2.4.56";
|
private final static String coreVersion = "2.4.57";
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This is specific to the website api
|
* This is specific to the website api
|
||||||
|
87
Core/src/main/java/com/songoda/core/math/Eval.java
Normal file
87
Core/src/main/java/com/songoda/core/math/Eval.java
Normal file
@ -0,0 +1,87 @@
|
|||||||
|
package com.songoda.core.math;
|
||||||
|
|
||||||
|
public class Eval {
|
||||||
|
|
||||||
|
private int pos = -1, ch;
|
||||||
|
private final String toParse;
|
||||||
|
private final String warningMessage;
|
||||||
|
|
||||||
|
public Eval(String toParse, String warningMessage) {
|
||||||
|
this.toParse = toParse;
|
||||||
|
this.warningMessage = warningMessage + " ";
|
||||||
|
}
|
||||||
|
|
||||||
|
private void nextChar() {
|
||||||
|
ch = (++pos < toParse.length()) ? toParse.charAt(pos) : -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean eat(int charToEat) {
|
||||||
|
while (ch == ' ') nextChar();
|
||||||
|
if (ch == charToEat) {
|
||||||
|
nextChar();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public double parse() {
|
||||||
|
nextChar();
|
||||||
|
double x = parseExpression();
|
||||||
|
if (pos < toParse.length()) throw new RuntimeException(warningMessage + "Unexpected: " + (char)ch);
|
||||||
|
return x;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Grammar:
|
||||||
|
// expression = term | expression `+` term | expression `-` term
|
||||||
|
// term = factor | term `*` factor | term `/` factor
|
||||||
|
// factor = `+` factor | `-` factor | `(` expression `)`
|
||||||
|
// | number | functionName factor | factor `^` factor
|
||||||
|
|
||||||
|
private double parseExpression() {
|
||||||
|
double x = parseTerm();
|
||||||
|
for (;;) {
|
||||||
|
if (eat('+')) x += parseTerm(); // addition
|
||||||
|
else if (eat('-')) x -= parseTerm(); // subtraction
|
||||||
|
else return x;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private double parseTerm() {
|
||||||
|
double x = parseFactor();
|
||||||
|
for (;;) {
|
||||||
|
if (eat('*')) x *= parseFactor(); // multiplication
|
||||||
|
else if (eat('/')) x /= parseFactor(); // division
|
||||||
|
else return x;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private double parseFactor() {
|
||||||
|
if (eat('+')) return parseFactor(); // unary plus
|
||||||
|
if (eat('-')) return -parseFactor(); // unary minus
|
||||||
|
|
||||||
|
double x;
|
||||||
|
int startPos = this.pos;
|
||||||
|
if (eat('(')) { // parentheses
|
||||||
|
x = parseExpression();
|
||||||
|
eat(')');
|
||||||
|
} else if ((ch >= '0' && ch <= '9') || ch == '.') { // numbers
|
||||||
|
while ((ch >= '0' && ch <= '9') || ch == '.') nextChar();
|
||||||
|
x = Double.parseDouble(toParse.substring(startPos, this.pos));
|
||||||
|
} else if (ch >= 'a' && ch <= 'z') { // functions
|
||||||
|
while (ch >= 'a' && ch <= 'z') nextChar();
|
||||||
|
String func = toParse.substring(startPos, this.pos);
|
||||||
|
x = parseFactor();
|
||||||
|
if (func.equals("sqrt")) x = Math.sqrt(x);
|
||||||
|
else if (func.equals("sin")) x = Math.sin(Math.toRadians(x));
|
||||||
|
else if (func.equals("cos")) x = Math.cos(Math.toRadians(x));
|
||||||
|
else if (func.equals("tan")) x = Math.tan(Math.toRadians(x));
|
||||||
|
else throw new RuntimeException(warningMessage + "Unknown function: " + func);
|
||||||
|
} else {
|
||||||
|
throw new RuntimeException(warningMessage + "Unexpected: " + (char)ch);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (eat('^')) x = Math.pow(x, parseFactor()); // exponentiation
|
||||||
|
|
||||||
|
return x;
|
||||||
|
}
|
||||||
|
}
|
17
Core/src/main/java/com/songoda/core/math/MathUtils.java
Normal file
17
Core/src/main/java/com/songoda/core/math/MathUtils.java
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
package com.songoda.core.math;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
public class MathUtils {
|
||||||
|
|
||||||
|
private static final Map<String, Double> cache = new HashMap<>();
|
||||||
|
|
||||||
|
public static double eval(String toParse) {
|
||||||
|
return eval(toParse, "SongodaCore Eval Engine");
|
||||||
|
}
|
||||||
|
|
||||||
|
public static double eval(String toParse, String warningMessage) {
|
||||||
|
return cache.computeIfAbsent(toParse, t -> new Eval(toParse, "[" + warningMessage + "]").parse());
|
||||||
|
}
|
||||||
|
}
|
@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>com.songoda</groupId>
|
<groupId>com.songoda</groupId>
|
||||||
<artifactId>SongodaCore-Modules</artifactId>
|
<artifactId>SongodaCore-Modules</artifactId>
|
||||||
<version>2.4.56</version>
|
<version>2.4.57</version>
|
||||||
<relativePath>../../</relativePath>
|
<relativePath>../../</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>com.songoda</groupId>
|
<groupId>com.songoda</groupId>
|
||||||
<artifactId>SongodaCore-Modules</artifactId>
|
<artifactId>SongodaCore-Modules</artifactId>
|
||||||
<version>2.4.56</version>
|
<version>2.4.57</version>
|
||||||
<relativePath>../../</relativePath>
|
<relativePath>../../</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>com.songoda</groupId>
|
<groupId>com.songoda</groupId>
|
||||||
<artifactId>SongodaCore-Modules</artifactId>
|
<artifactId>SongodaCore-Modules</artifactId>
|
||||||
<version>2.4.56</version>
|
<version>2.4.57</version>
|
||||||
<relativePath>../../</relativePath>
|
<relativePath>../../</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>com.songoda</groupId>
|
<groupId>com.songoda</groupId>
|
||||||
<artifactId>SongodaCore-Modules</artifactId>
|
<artifactId>SongodaCore-Modules</artifactId>
|
||||||
<version>2.4.56</version>
|
<version>2.4.57</version>
|
||||||
<relativePath>../../</relativePath>
|
<relativePath>../../</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>com.songoda</groupId>
|
<groupId>com.songoda</groupId>
|
||||||
<artifactId>SongodaCore-Modules</artifactId>
|
<artifactId>SongodaCore-Modules</artifactId>
|
||||||
<version>2.4.56</version>
|
<version>2.4.57</version>
|
||||||
<relativePath>../../</relativePath>
|
<relativePath>../../</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>com.songoda</groupId>
|
<groupId>com.songoda</groupId>
|
||||||
<artifactId>SongodaCore-Modules</artifactId>
|
<artifactId>SongodaCore-Modules</artifactId>
|
||||||
<version>2.4.56</version>
|
<version>2.4.57</version>
|
||||||
<relativePath>../../</relativePath>
|
<relativePath>../../</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>com.songoda</groupId>
|
<groupId>com.songoda</groupId>
|
||||||
<artifactId>SongodaCore-Modules</artifactId>
|
<artifactId>SongodaCore-Modules</artifactId>
|
||||||
<version>2.4.56</version>
|
<version>2.4.57</version>
|
||||||
<relativePath>../../</relativePath>
|
<relativePath>../../</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>com.songoda</groupId>
|
<groupId>com.songoda</groupId>
|
||||||
<artifactId>SongodaCore-Modules</artifactId>
|
<artifactId>SongodaCore-Modules</artifactId>
|
||||||
<version>2.4.56</version>
|
<version>2.4.57</version>
|
||||||
<relativePath>../../</relativePath>
|
<relativePath>../../</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>com.songoda</groupId>
|
<groupId>com.songoda</groupId>
|
||||||
<artifactId>SongodaCore-Modules</artifactId>
|
<artifactId>SongodaCore-Modules</artifactId>
|
||||||
<version>2.4.56</version>
|
<version>2.4.57</version>
|
||||||
<relativePath>../../</relativePath>
|
<relativePath>../../</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>com.songoda</groupId>
|
<groupId>com.songoda</groupId>
|
||||||
<artifactId>SongodaCore-Modules</artifactId>
|
<artifactId>SongodaCore-Modules</artifactId>
|
||||||
<version>2.4.56</version>
|
<version>2.4.57</version>
|
||||||
<relativePath>../../</relativePath>
|
<relativePath>../../</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>com.songoda</groupId>
|
<groupId>com.songoda</groupId>
|
||||||
<artifactId>SongodaCore-Modules</artifactId>
|
<artifactId>SongodaCore-Modules</artifactId>
|
||||||
<version>2.4.56</version>
|
<version>2.4.57</version>
|
||||||
<relativePath>../../</relativePath>
|
<relativePath>../../</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>com.songoda</groupId>
|
<groupId>com.songoda</groupId>
|
||||||
<artifactId>SongodaCore-Modules</artifactId>
|
<artifactId>SongodaCore-Modules</artifactId>
|
||||||
<version>2.4.56</version>
|
<version>2.4.57</version>
|
||||||
<relativePath>../../</relativePath>
|
<relativePath>../../</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>com.songoda</groupId>
|
<groupId>com.songoda</groupId>
|
||||||
<artifactId>SongodaCore-Modules</artifactId>
|
<artifactId>SongodaCore-Modules</artifactId>
|
||||||
<version>2.4.56</version>
|
<version>2.4.57</version>
|
||||||
<relativePath>../../</relativePath>
|
<relativePath>../../</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>com.songoda</groupId>
|
<groupId>com.songoda</groupId>
|
||||||
<artifactId>SongodaCore-Modules</artifactId>
|
<artifactId>SongodaCore-Modules</artifactId>
|
||||||
<version>2.4.56</version>
|
<version>2.4.57</version>
|
||||||
<relativePath>../../</relativePath>
|
<relativePath>../../</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>com.songoda</groupId>
|
<groupId>com.songoda</groupId>
|
||||||
<artifactId>SongodaCore-Modules</artifactId>
|
<artifactId>SongodaCore-Modules</artifactId>
|
||||||
<version>2.4.56</version>
|
<version>2.4.57</version>
|
||||||
<relativePath>../../</relativePath>
|
<relativePath>../../</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
<parent>
|
<parent>
|
||||||
<groupId>com.songoda</groupId>
|
<groupId>com.songoda</groupId>
|
||||||
<artifactId>SongodaCore-Modules</artifactId>
|
<artifactId>SongodaCore-Modules</artifactId>
|
||||||
<version>2.4.56</version>
|
<version>2.4.57</version>
|
||||||
<relativePath>../../</relativePath>
|
<relativePath>../../</relativePath>
|
||||||
</parent>
|
</parent>
|
||||||
|
|
||||||
|
@ -18,7 +18,7 @@ Maven Information
|
|||||||
<dependency>
|
<dependency>
|
||||||
<groupId>com.songoda</groupId>
|
<groupId>com.songoda</groupId>
|
||||||
<artifactId>SongodaCore</artifactId>
|
<artifactId>SongodaCore</artifactId>
|
||||||
<version>2.4.56</version>
|
<version>2.4.57</version>
|
||||||
<scope>provided</scope>
|
<scope>provided</scope>
|
||||||
</dependency>
|
</dependency>
|
||||||
```
|
```
|
||||||
@ -37,6 +37,6 @@ repositories {
|
|||||||
* Artifact:
|
* Artifact:
|
||||||
```groovy
|
```groovy
|
||||||
dependencies {
|
dependencies {
|
||||||
compileOnly 'com.songoda:SongodaCore:2.4.56'
|
compileOnly 'com.songoda:SongodaCore:2.4.57'
|
||||||
}
|
}
|
||||||
```
|
```
|
2
pom.xml
2
pom.xml
@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
<groupId>com.songoda</groupId>
|
<groupId>com.songoda</groupId>
|
||||||
<artifactId>SongodaCore-Modules</artifactId>
|
<artifactId>SongodaCore-Modules</artifactId>
|
||||||
<version>2.4.56</version>
|
<version>2.4.57</version>
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<packaging>pom</packaging>
|
<packaging>pom</packaging>
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user