Spaces:
Running
Running
; | |
Object.defineProperty(exports, "__esModule", { value: true }); | |
exports.dynamicRef = void 0; | |
const codegen_1 = require("../../compile/codegen"); | |
const names_1 = require("../../compile/names"); | |
const ref_1 = require("../core/ref"); | |
const def = { | |
keyword: "$dynamicRef", | |
schemaType: "string", | |
code: (cxt) => dynamicRef(cxt, cxt.schema), | |
}; | |
function dynamicRef(cxt, ref) { | |
const { gen, keyword, it } = cxt; | |
if (ref[0] !== "#") | |
throw new Error(`"${keyword}" only supports hash fragment reference`); | |
const anchor = ref.slice(1); | |
if (it.allErrors) { | |
_dynamicRef(); | |
} | |
else { | |
const valid = gen.let("valid", false); | |
_dynamicRef(valid); | |
cxt.ok(valid); | |
} | |
function _dynamicRef(valid) { | |
// TODO the assumption here is that `recursiveRef: #` always points to the root | |
// of the schema object, which is not correct, because there may be $id that | |
// makes # point to it, and the target schema may not contain dynamic/recursiveAnchor. | |
// Because of that 2 tests in recursiveRef.json fail. | |
// This is a similar problem to #815 (`$id` doesn't alter resolution scope for `{ "$ref": "#" }`). | |
// (This problem is not tested in JSON-Schema-Test-Suite) | |
if (it.schemaEnv.root.dynamicAnchors[anchor]) { | |
const v = gen.let("_v", (0, codegen_1._) `${names_1.default.dynamicAnchors}${(0, codegen_1.getProperty)(anchor)}`); | |
gen.if(v, _callRef(v, valid), _callRef(it.validateName, valid)); | |
} | |
else { | |
_callRef(it.validateName, valid)(); | |
} | |
} | |
function _callRef(validate, valid) { | |
return valid | |
? () => gen.block(() => { | |
(0, ref_1.callRef)(cxt, validate); | |
gen.let(valid, true); | |
}) | |
: () => (0, ref_1.callRef)(cxt, validate); | |
} | |
} | |
exports.dynamicRef = dynamicRef; | |
exports.default = def; | |
//# sourceMappingURL=dynamicRef.js.map |