avancement planning
This commit is contained in:
+13
-2
@@ -228,8 +228,19 @@ function serializeString({gen, data}: SerializeCxt): void {
|
||||
gen.add(N.json, _`${useFunc(gen, quote)}(${data})`)
|
||||
}
|
||||
|
||||
function serializeNumber({gen, data}: SerializeCxt): void {
|
||||
gen.add(N.json, _`"" + ${data}`)
|
||||
function serializeNumber({gen, data, self}: SerializeCxt): void {
|
||||
const condition = _`${data} === Infinity || ${data} === -Infinity || ${data} !== ${data}`
|
||||
|
||||
if (self.opts.specialNumbers === undefined || self.opts.specialNumbers === "fast") {
|
||||
gen.add(N.json, _`"" + ${data}`)
|
||||
} else {
|
||||
// specialNumbers === "null"
|
||||
gen.if(
|
||||
condition,
|
||||
() => gen.add(N.json, _`null`),
|
||||
() => gen.add(N.json, _`"" + ${data}`)
|
||||
)
|
||||
}
|
||||
}
|
||||
|
||||
function serializeRef(cxt: SerializeCxt): void {
|
||||
|
||||
+1
@@ -107,6 +107,7 @@ export interface CurrentOptions {
|
||||
timestamp?: "string" | "date" // JTD only
|
||||
parseDate?: boolean // JTD only
|
||||
allowDate?: boolean // JTD only
|
||||
specialNumbers?: "fast" | "null" // JTD only
|
||||
$comment?:
|
||||
| true
|
||||
| ((comment: string, schemaPath?: string, rootSchema?: AnySchemaObject) => unknown)
|
||||
|
||||
+15
-4
@@ -1,6 +1,7 @@
|
||||
import type {CodeKeywordDefinition, ErrorObject, KeywordErrorDefinition} from "../../types"
|
||||
import type {KeywordCxt} from "../../compile/validate"
|
||||
import {usePattern} from "../code"
|
||||
import {useFunc} from "../../compile/util"
|
||||
import {_, str} from "../../compile/codegen"
|
||||
|
||||
export type PatternError = ErrorObject<"pattern", {pattern: string}, string | {$data: string}>
|
||||
@@ -17,11 +18,21 @@ const def: CodeKeywordDefinition = {
|
||||
$data: true,
|
||||
error,
|
||||
code(cxt: KeywordCxt) {
|
||||
const {data, $data, schema, schemaCode, it} = cxt
|
||||
// TODO regexp should be wrapped in try/catchs
|
||||
const {gen, data, $data, schema, schemaCode, it} = cxt
|
||||
const u = it.opts.unicodeRegExp ? "u" : ""
|
||||
const regExp = $data ? _`(new RegExp(${schemaCode}, ${u}))` : usePattern(cxt, schema)
|
||||
cxt.fail$data(_`!${regExp}.test(${data})`)
|
||||
if ($data) {
|
||||
const {regExp} = it.opts.code
|
||||
const regExpCode = regExp.code === "new RegExp" ? _`new RegExp` : useFunc(gen, regExp)
|
||||
const valid = gen.let("valid")
|
||||
gen.try(
|
||||
() => gen.assign(valid, _`${regExpCode}(${schemaCode}, ${u}).test(${data})`),
|
||||
() => gen.assign(valid, false)
|
||||
)
|
||||
cxt.fail$data(_`!${valid}`)
|
||||
} else {
|
||||
const regExp = usePattern(cxt, schema)
|
||||
cxt.fail$data(_`!${regExp}.test(${data})`)
|
||||
}
|
||||
},
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user