avancement planning
This commit is contained in:
+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