Fixed bugs.
All checks were successful
continuous-integration/drone/push Build is passing

1. X Cursors pointing to an object when LaTeX is enabled make LogarithmPlotter crash due to invalid LaTeX.
2. Invalid class-property types are now directly generated from the static instance.
3. Sequences didn't include sequence value properly anymore.
This commit is contained in:
Adsooi 2022-10-19 01:49:30 +02:00
parent dc532fcd19
commit b519e34016
Signed by: Ad5001
GPG key ID: 7251B1AF90B960F9
9 changed files with 5 additions and 11 deletions

View file

@ -252,7 +252,6 @@ Item {
let tokenizer = new Parsing.Tokenizer(new Parsing.Input(text), true, false) let tokenizer = new Parsing.Tokenizer(new Parsing.Input(text), true, false)
let parsedText = "" let parsedText = ""
let token let token
console.log("Parsing text:", parsedText)
while((token = tokenizer.next()) != null) { while((token = tokenizer.next()) != null) {
switch(token.type) { switch(token.type) {
case Parsing.TokenType.VARIABLE: case Parsing.TokenType.VARIABLE:
@ -280,7 +279,6 @@ Item {
break; break;
} }
} }
console.log("Parsed text:", parsedText)
return parsedText return parsedText
} }
} }

View file

@ -66,9 +66,10 @@ class Sequence extends Expr.Expression {
var str = Utils.simplifyExpression(this.calc.substitute('n', n-this.valuePlus).toString()) var str = Utils.simplifyExpression(this.calc.substitute('n', n-this.valuePlus).toString())
var expr = C.parser.parse(str).simplify() var expr = C.parser.parse(str).simplify()
C.currentVars = Object.assign( C.currentVars = Object.assign(
{'n': n-this.valuePlus, [this.name]: this.calcValues}, // Just in case, add n (for custom functions) {'n': n-this.valuePlus}, // Just in case, add n (for custom functions)
C.currentObjectsByName C.currentObjectsByName
) )
C.currentVars[this.name] = this.calcValues
this.calcValues[n] = expr.evaluate(C.currentVars) this.calcValues[n] = expr.evaluate(C.currentVars)
} }

View file

@ -112,7 +112,7 @@ class DrawableObject {
*/ */
constructor(name, visible = true, color = null, labelContent = 'name + value') { constructor(name, visible = true, color = null, labelContent = 'name + value') {
if(color == null) color = Utils.getRandomColor() if(color == null) color = Utils.getRandomColor()
this.type = 'Unknown' this.type = this.constructor.type()
this.name = name this.name = name
this.visible = visible this.visible = visible
this.color = color this.color = color

View file

@ -54,7 +54,6 @@ class Function extends Common.ExecutableObject {
drawPoints = true, drawDashedLines = true) { drawPoints = true, drawDashedLines = true) {
if(name == null) name = Common.getNewName('fghjqlmnopqrstuvwabcde') if(name == null) name = Common.getNewName('fghjqlmnopqrstuvwabcde')
super(name, visible, color, labelContent) super(name, visible, color, labelContent)
this.type = 'Function'
if(typeof expression == 'number' || typeof expression == 'string') expression = new MathLib.Expression(expression.toString()) if(typeof expression == 'number' || typeof expression == 'string') expression = new MathLib.Expression(expression.toString())
this.expression = expression this.expression = expression
if(typeof definitionDomain == 'string') definitionDomain = MathLib.parseDomain(definitionDomain) if(typeof definitionDomain == 'string') definitionDomain = MathLib.parseDomain(definitionDomain)

View file

@ -46,7 +46,6 @@ class GainBode extends Common.ExecutableObject {
if(name == null) name = Common.getNewName('G') if(name == null) name = Common.getNewName('G')
if(name == 'G') name = 'G₀' // G is reserved for sum of BODE magnitudes (Somme gains Bode). if(name == 'G') name = 'G₀' // G is reserved for sum of BODE magnitudes (Somme gains Bode).
super(name, visible, color, labelContent) super(name, visible, color, labelContent)
this.type = 'Gain Bode'
if(typeof om_0 == "string") { if(typeof om_0 == "string") {
// Point name or create one // Point name or create one
om_0 = Objects.currentObjectsByName[om_0] om_0 = Objects.currentObjectsByName[om_0]

View file

@ -43,7 +43,6 @@ class PhaseBode extends Common.ExecutableObject {
if(name == null) name = Common.getNewName('φ') if(name == null) name = Common.getNewName('φ')
if(name == 'φ') name = 'φ₀' // φ is reserved for sum of BODE phases (Somme phases Bode). if(name == 'φ') name = 'φ₀' // φ is reserved for sum of BODE phases (Somme phases Bode).
super(name, visible, color, labelContent) super(name, visible, color, labelContent)
this.type = 'Phase Bode'
if(typeof phase == 'number' || typeof phase == 'string') phase = new MathLib.Expression(phase.toString()) if(typeof phase == 'number' || typeof phase == 'string') phase = new MathLib.Expression(phase.toString())
this.phase = phase this.phase = phase
if(typeof om_0 == "string") { if(typeof om_0 == "string") {

View file

@ -40,7 +40,6 @@ class Point extends Common.DrawableObject {
x = 1, y = 0, labelPosition = 'above', pointStyle = '●') { x = 1, y = 0, labelPosition = 'above', pointStyle = '●') {
if(name == null) name = Common.getNewName('ABCDEFJKLMNOPQRSTUVW') if(name == null) name = Common.getNewName('ABCDEFJKLMNOPQRSTUVW')
super(name, visible, color, labelContent) super(name, visible, color, labelContent)
this.type = 'Point'
if(typeof x == 'number' || typeof x == 'string') x = new MathLib.Expression(x.toString()) if(typeof x == 'number' || typeof x == 'string') x = new MathLib.Expression(x.toString())
this.x = x this.x = x
if(typeof y == 'number' || typeof y == 'string') y = new MathLib.Expression(y.toString()) if(typeof y == 'number' || typeof y == 'string') y = new MathLib.Expression(y.toString())

View file

@ -45,7 +45,6 @@ class Text extends Common.DrawableObject {
x = 1, y = 0, labelPosition = 'center', text = 'New text', disableLatex = false) { x = 1, y = 0, labelPosition = 'center', text = 'New text', disableLatex = false) {
if(name == null) name = Common.getNewName('t') if(name == null) name = Common.getNewName('t')
super(name, visible, color, labelContent) super(name, visible, color, labelContent)
this.type = 'Text'
if(typeof x == 'number' || typeof x == 'string') x = new MathLib.Expression(x.toString()) if(typeof x == 'number' || typeof x == 'string') x = new MathLib.Expression(x.toString())
this.x = x this.x = x
if(typeof y == 'number' || typeof y == 'string') y = new MathLib.Expression(y.toString()) if(typeof y == 'number' || typeof y == 'string') y = new MathLib.Expression(y.toString())

View file

@ -49,7 +49,6 @@ class XCursor extends Common.DrawableObject {
rounding = 3, displayStyle = '— — — — — — —', targetValuePosition = 'Next to target') { rounding = 3, displayStyle = '— — — — — — —', targetValuePosition = 'Next to target') {
if(name == null) name = Common.getNewName('X') if(name == null) name = Common.getNewName('X')
super(name, visible, color, labelContent) super(name, visible, color, labelContent)
this.type = 'X Cursor'
this.approximate = approximate this.approximate = approximate
this.rounding = rounding this.rounding = rounding
if(typeof x == 'number' || typeof x == 'string') x = new MathLib.Expression(x.toString()) if(typeof x == 'number' || typeof x == 'string') x = new MathLib.Expression(x.toString())
@ -78,7 +77,8 @@ class XCursor extends Common.DrawableObject {
if(this.targetElement == null) return `${Latex.variable(this.name)} = ${this.x.latexMarkup}` if(this.targetElement == null) return `${Latex.variable(this.name)} = ${this.x.latexMarkup}`
return `\\begin{array}{l} return `\\begin{array}{l}
${Latex.variable(this.name)} = ${this.x.latexMarkup} \\\\ ${Latex.variable(this.name)} = ${this.x.latexMarkup} \\\\
${this.getTargetValueLatexLabel()}` ${this.getTargetValueLatexLabel()}
\\end{array}`
} }
getTargetValueLabel() { getTargetValueLabel() {