Commit 1be336de authored by Boris Kocherov's avatar Boris Kocherov

merging shemas

parent 306ead65
...@@ -5,6 +5,12 @@ ...@@ -5,6 +5,12 @@
"use strict"; "use strict";
var expandSchema; var expandSchema;
function arrayIntersect(x, y) {
return x.filter(function (value) {
return y.indexOf(value) >= 0;
});
}
function URLwithJio(url, base_url) { function URLwithJio(url, base_url) {
var urn_prefix, var urn_prefix,
pathname, pathname,
...@@ -309,7 +315,141 @@ ...@@ -309,7 +315,141 @@
}); });
} }
function allOf(g, schema_array, schema_path) { function mergeSchemas(x, y, doesntcopy) {
if (x === true && y === true) {
return true;
}
if (x === false || y === false) {
return false;
}
var key,
p;
if (x === true) {
x = {};
} else if (!doesntcopy) {
x = JSON.parse(JSON.stringify(x));
}
if (y === true) {
y = {};
}
for (key in y) {
if (y.hasOwnProperty(key)) {
if (x.hasOwnProperty(key)) {
switch (key) {
case "maxProperties":
case "maxLength":
case "maxItems":
case "maximum":
case "exclusiveMaximum":
if (y[key] < x[key]) {
x[key] = y[key];
}
break;
case "minProperties":
case "minItems":
case "minLength":
case "minimum":
case "exclusiveMinimum":
if (x[key] < y[key]) {
x[key] = y[key];
}
break;
case "additionalProperties":
case "additionalItems":
case "contains":
case "propertyNames":
mergeSchemas(x[key], y[key], true);
break;
case "items":
// XXX items can be array
mergeSchemas(x[key], y[key], true);
break;
case "contentEncoding":
case "contentMediaType":
if (x[key] !== y[key]) {
return false;
}
break;
case "multipleOf":
x[key] = x[key] * y[key];
break;
case "type":
if (typeof x.type === "string") {
if (typeof y.type === "string") {
if (x.type !== y.type) {
return false;
}
} else if (y.type.indexOf(x.type) === -1) {
return false;
}
} else {
if (typeof y.type === "string") {
if (x.type.indexOf(y.type) === -1) {
return false;
}
} else {
x.type = arrayIntersect(x.type, y.type);
if (x.type.length === 0) {
return false;
}
}
}
break;
case "properties":
case "patternProperties":
for (p in y[key]) {
if (y[key].hasOwnProperty(p)) {
if (x[key].hasOwnProperty(p)) {
mergeSchemas(x[key][p], y[key][p], true);
} else {
x[key][p] = y[key][p];
}
}
}
break;
case "pattern":
// XXX regex string merge
case "dependencies":
// XXX find solution how merge
x[key] = y[key];
break;
case "required":
for (p = 0; p < y.required.length; p += 1) {
if (x.required.indexOf(y.required[p]) < 0) {
x.required.push(y.required[p]);
}
}
break;
case "uniqueItems":
x[key] = y[key];
break;
case "allOf":
case "anyOf":
case "$ref":
case "id":
case "$id":
// XXX
break;
default:
// XXX
x[key] = y[key];
}
} else {
switch (key) {
case "allOf":
case "anyOf":
case "$ref":
break;
default:
x[key] = y[key];
}
}
}
}
return x;
}
function allOf(g, schema_array, schema_path, base_schema) {
return RSVP.Queue() return RSVP.Queue()
.push(function () { .push(function () {
var i, var i,
...@@ -323,10 +463,8 @@ ...@@ -323,10 +463,8 @@
var i, var i,
x, x,
y, y,
key,
next_schema, next_schema,
schema, schema,
schema_item,
summ_arr; summ_arr;
for (i = 0; i < arr.length - 1; i += 1) { for (i = 0; i < arr.length - 1; i += 1) {
summ_arr = []; summ_arr = [];
...@@ -334,46 +472,20 @@ ...@@ -334,46 +472,20 @@
for (y = 0; y < arr[i + 1].length; y += 1) { for (y = 0; y < arr[i + 1].length; y += 1) {
schema = arr[i][x].schema; schema = arr[i][x].schema;
next_schema = arr[i + 1][y].schema; next_schema = arr[i + 1][y].schema;
if (schema === true && next_schema === true) { schema = mergeSchemas(schema, next_schema);
schema_item = { summ_arr.push({
schema: true, schema: schema,
schema_path: arr[i][x].schema_path // XXX we loss path arr[i + 1][y].schema_path
}; schema_path: arr[i][x].schema_path
} else if (schema === false || next_schema === false) { });
schema_item = {
schema: false,
schema_path: arr[i][x].schema_path
};
} else {
if (schema === true) {
schema = {};
}
if (next_schema === true) {
next_schema = {};
}
// copy before change
schema = JSON.parse(JSON.stringify(schema));
for (key in next_schema) {
if (next_schema.hasOwnProperty(key)) {
if (schema.hasOwnProperty(key)) {
// XXX need use many many rules for merging
schema[key] = next_schema[key];
} else {
schema[key] = next_schema[key];
}
}
}
schema_item = {
schema: schema,
schema_path: arr[i][x].schema_path
};
}
summ_arr.push(schema_item);
} }
} }
arr[i + 1] = summ_arr; arr[i + 1] = summ_arr;
} }
return arr[arr.length - 1]; for (x = 0; x < summ_arr.length; x += 1) {
summ_arr[x].schema = mergeSchemas(summ_arr[x].schema, base_schema);
}
return summ_arr;
}); });
} }
...@@ -416,7 +528,7 @@ ...@@ -416,7 +528,7 @@
return anyOf(g, schema.anyOf, schema_path); return anyOf(g, schema.anyOf, schema_path);
} }
if (schema.allOf !== undefined) { if (schema.allOf !== undefined) {
return allOf(g, schema.allOf, schema_path); return allOf(g, schema.allOf, schema_path, schema);
} }
if (schema.$ref) { if (schema.$ref) {
return loadJSONSchema(g, schema.$ref, schema_path); return loadJSONSchema(g, schema.$ref, schema_path);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment