hexo/node_modules/ajv/dist/vocabularies/applicator/items.js

51 lines
2.0 KiB
JavaScript

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const codegen_1 = require("../../compile/codegen");
const util_1 = require("../../compile/util");
const validate_1 = require("../../compile/validate");
const code_1 = require("../code");
const def = {
keyword: "items",
type: "array",
schemaType: ["object", "array", "boolean"],
before: "uniqueItems",
code(cxt) {
const { gen, schema, it } = cxt;
if (Array.isArray(schema)) {
if (it.opts.unevaluated && schema.length && it.items !== true) {
it.items = util_1.mergeEvaluated.items(gen, schema.length, it.items);
}
validateTuple(schema);
}
else {
it.items = true;
if (util_1.alwaysValidSchema(it, schema))
return;
cxt.ok(code_1.validateArray(cxt));
}
function validateTuple(schArr) {
const { parentSchema, data } = cxt;
if (it.opts.strictTuples && !fullTupleSchema(schArr.length, parentSchema)) {
const msg = `"items" is ${schArr.length}-tuple, but minItems or maxItems/additionalItems are not specified or different`;
validate_1.checkStrictMode(it, msg, it.opts.strictTuples);
}
const valid = gen.name("valid");
const len = gen.const("len", codegen_1._ `${data}.length`);
schArr.forEach((sch, i) => {
if (util_1.alwaysValidSchema(it, sch))
return;
gen.if(codegen_1._ `${len} > ${i}`, () => cxt.subschema({
keyword: "items",
schemaProp: i,
dataProp: i,
}, valid));
cxt.ok(valid);
});
}
},
};
function fullTupleSchema(len, sch) {
return len === sch.minItems && (len === sch.maxItems || sch.additionalItems === false);
}
exports.default = def;
//# sourceMappingURL=items.js.map