Units separated to their own block, and properly tested

This commit is contained in:
Bán Dénes 2021-07-11 13:45:53 +02:00
parent 71efdbe020
commit 452d7c155b
7 changed files with 100 additions and 19 deletions

View file

@ -1,4 +1,5 @@
const prepare = require('./prepare')
const units_lib = require('./units')
const points_lib = require('./points')
const outlines_lib = require('./outlines')
const cases_lib = require('./cases')
@ -15,13 +16,17 @@ module.exports = {
config = prepare.inherit(config)
const results = {}
logger('Parsing points...')
const [points, units] = points_lib.parse(config.points)
// parsing units
logger('Calculating variables...')
const units = units_lib.parse(config)
if (debug) {
results.points = {
data: points,
units: units
}
results.units = units
}
logger('Parsing points...')
const points = points_lib.parse(config.points, units)
if (debug) {
results.points = points
}
logger('Generating outlines...')

View file

@ -215,18 +215,7 @@ const perform_mirror = exports._perform_mirror = (point, axis) => {
return ['', null]
}
exports.parse = (config = {}) => {
// parsing units
const raw_units = prep.extend({
u: 19,
cx: 18,
cy: 17
}, a.sane(config.units || {}, 'points.units', 'object')())
const units = {}
for (const [key, val] of Object.entries(raw_units)) {
units[key] = a.mathnum(val)(units)
}
exports.parse = (config, units) => {
// config sanitization
a.unexpected(config, 'points', ['units', 'zones', 'key', 'rotate', 'mirror'])
@ -317,7 +306,7 @@ exports.parse = (config = {}) => {
}
// done
return [filtered, units]
return filtered
}
exports.visualize = (points) => {

21
src/units.js Normal file
View file

@ -0,0 +1,21 @@
const a = require('./assert')
const prep = require('./prepare')
const default_units = {
u: 19,
cx: 18,
cy: 17
}
exports.parse = (config = {}) => {
const raw_units = prep.extend(
default_units,
a.sane(config.units || {}, 'units', 'object')(),
a.sane(config.variables || {}, 'variables', 'object')()
)
const units = {}
for (const [key, val] of Object.entries(raw_units)) {
units[key] = a.mathnum(val)(units)
}
return units
}