From 9bce51f651aad297ef9eb6df832bfdaf1de05d84 Mon Sep 17 00:00:00 2001
From: WXL <wl_5969728@163.com>
Date: 星期三, 22 四月 2026 14:27:54 +0800
Subject: [PATCH] 青岛推送
---
node_modules/ajv/dist/vocabularies/validation/pattern.js | 17 +++++++++++++----
1 files changed, 13 insertions(+), 4 deletions(-)
diff --git a/node_modules/ajv/dist/vocabularies/validation/pattern.js b/node_modules/ajv/dist/vocabularies/validation/pattern.js
index f8ccdf2..913f7ba 100644
--- a/node_modules/ajv/dist/vocabularies/validation/pattern.js
+++ b/node_modules/ajv/dist/vocabularies/validation/pattern.js
@@ -1,6 +1,7 @@
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const code_1 = require("../code");
+const util_1 = require("../../compile/util");
const codegen_1 = require("../../compile/codegen");
const error = {
message: ({ schemaCode }) => (0, codegen_1.str) `must match pattern "${schemaCode}"`,
@@ -13,11 +14,19 @@
$data: true,
error,
code(cxt) {
- 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 ? (0, codegen_1._) `(new RegExp(${schemaCode}, ${u}))` : (0, code_1.usePattern)(cxt, schema);
- cxt.fail$data((0, codegen_1._) `!${regExp}.test(${data})`);
+ if ($data) {
+ const { regExp } = it.opts.code;
+ const regExpCode = regExp.code === "new RegExp" ? (0, codegen_1._) `new RegExp` : (0, util_1.useFunc)(gen, regExp);
+ const valid = gen.let("valid");
+ gen.try(() => gen.assign(valid, (0, codegen_1._) `${regExpCode}(${schemaCode}, ${u}).test(${data})`), () => gen.assign(valid, false));
+ cxt.fail$data((0, codegen_1._) `!${valid}`);
+ }
+ else {
+ const regExp = (0, code_1.usePattern)(cxt, schema);
+ cxt.fail$data((0, codegen_1._) `!${regExp}.test(${data})`);
+ }
},
};
exports.default = def;
--
Gitblit v1.9.3