Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
R
rapidjson
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
rapidjson
Commits
3873bcb7
Commit
3873bcb7
authored
May 09, 2015
by
miloyip
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fix some remote ref issues
parent
42f1194a
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
44 additions
and
21 deletions
+44
-21
stack.h
include/rapidjson/internal/stack.h
+15
-0
schema.h
include/rapidjson/schema.h
+25
-16
schematest.cpp
test/unittest/schematest.cpp
+4
-5
No files found.
include/rapidjson/internal/stack.h
View file @
3873bcb7
...
...
@@ -121,9 +121,24 @@ public:
return
reinterpret_cast
<
T
*>
(
stackTop_
-
sizeof
(
T
));
}
template
<
typename
T
>
const
T
*
Top
()
const
{
RAPIDJSON_ASSERT
(
GetSize
()
>=
sizeof
(
T
));
return
reinterpret_cast
<
T
*>
(
stackTop_
-
sizeof
(
T
));
}
template
<
typename
T
>
T
*
End
()
{
return
reinterpret_cast
<
T
*>
(
stackTop_
);
}
template
<
typename
T
>
const
T
*
End
()
const
{
return
reinterpret_cast
<
T
*>
(
stackTop_
);
}
template
<
typename
T
>
T
*
Bottom
()
{
return
(
T
*
)
stack_
;
}
template
<
typename
T
>
const
T
*
Bottom
()
const
{
return
(
T
*
)
stack_
;
}
Allocator
&
GetAllocator
()
{
return
*
allocator_
;
}
bool
Empty
()
const
{
return
stackTop_
==
stack_
;
}
size_t
GetSize
()
const
{
return
static_cast
<
size_t
>
(
stackTop_
-
stack_
);
}
...
...
include/rapidjson/schema.h
View file @
3873bcb7
...
...
@@ -882,7 +882,7 @@ public:
typedef
typename
ValueType
::
Ch
Ch
;
virtual
~
IGenericRemoteSchemaDocumentProvider
()
{}
virtual
SchemaDocumentType
*
GetRemoteDocument
(
const
Ch
*
uri
,
SizeType
length
)
=
0
;
virtual
const
SchemaDocumentType
*
GetRemoteDocument
(
const
Ch
*
uri
,
SizeType
length
)
=
0
;
};
typedef
IGenericRemoteSchemaDocumentProvider
<
Value
>
IRemoteSchemaDocumentProvider
;
...
...
@@ -909,10 +909,10 @@ public:
schemaMap_
(
allocator
,
kInitialSchemaMapSize
),
schemaRef_
(
allocator
,
kInitialSchemaRefSize
)
{
// Generate root schema, it will call CreateSchema() to create sub-schemas,
// And call AddRefSchema() if there are $ref.
root_
=
CreateSchema
(
PointerType
(),
static_cast
<
const
ValueType
&>
(
document
));
//root_ = CreateSchema(PointerType(), static_cast<const ValueType&>(document));
root_
=
CreateSchemaRecursive
(
Pointer
(),
static_cast
<
const
ValueType
&>
(
document
));
// Resolve $ref
while
(
!
schemaRef_
.
Empty
())
{
...
...
@@ -936,12 +936,27 @@ public:
private
:
struct
SchemaEntry
{
SchemaEntry
(
const
GenericPointer
<
ValueType
>
&
p
,
SchemaType
*
s
)
:
pointer
(
p
),
schema
(
s
)
{}
GenericPointer
<
ValueType
>
pointer
;
SchemaEntry
(
const
PointerType
&
p
,
SchemaType
*
s
)
:
pointer
(
p
),
schema
(
s
)
{}
PointerType
pointer
;
SchemaType
*
schema
;
};
const
SchemaType
*
CreateSchema
(
const
GenericPointer
<
ValueType
>&
pointer
,
const
ValueType
&
v
)
{
const
SchemaType
*
CreateSchemaRecursive
(
const
PointerType
&
pointer
,
const
ValueType
&
v
)
{
if
(
v
.
GetType
()
==
kObjectType
)
{
const
SchemaType
*
s
=
GetSchema
(
pointer
);
if
(
!
s
)
s
=
CreateSchema
(
pointer
,
v
);
for
(
typename
ValueType
::
ConstMemberIterator
itr
=
v
.
MemberBegin
();
itr
!=
v
.
MemberEnd
();
++
itr
)
CreateSchemaRecursive
(
pointer
.
Append
(
itr
->
name
),
itr
->
value
);
return
s
;
}
else
if
(
v
.
GetType
()
==
kArrayType
)
for
(
SizeType
i
=
0
;
i
<
v
.
Size
();
i
++
)
CreateSchemaRecursive
(
pointer
.
Append
(
i
),
v
[
i
]);
return
0
;
}
const
SchemaType
*
CreateSchema
(
const
PointerType
&
pointer
,
const
ValueType
&
v
)
{
RAPIDJSON_ASSERT
(
pointer
.
IsValid
());
SchemaType
*
schema
=
new
SchemaType
(
this
,
pointer
,
v
);
new
(
schemaMap_
.
template
Push
<
SchemaEntry
>
())
SchemaEntry
(
pointer
,
schema
);
...
...
@@ -959,8 +974,7 @@ private:
if
(
i
>
0
)
{
// Remote reference, resolve immediately
if
(
remoteProvider_
)
{
if
(
GenericSchemaDocument
*
remoteDocument
=
remoteProvider_
->
GetRemoteDocument
(
s
,
i
-
1
))
{
printf
(
"remote fragment: %*s
\n
"
,
len
-
i
,
&
s
[
i
]);
if
(
const
GenericSchemaDocument
*
remoteDocument
=
remoteProvider_
->
GetRemoteDocument
(
s
,
i
-
1
))
{
GenericPointer
<
ValueType
>
pointer
(
&
s
[
i
],
len
-
i
);
if
(
pointer
.
IsValid
())
schema
->
ref_
=
remoteDocument
->
GetSchema
(
pointer
);
...
...
@@ -968,7 +982,6 @@ private:
}
}
else
if
(
s
[
i
]
==
'#'
)
{
// Local reference, defer resolution
printf
(
"local fragment: %*s
\n
"
,
len
-
i
,
&
s
[
i
]);
GenericPointer
<
ValueType
>
pointer
(
&
s
[
i
],
len
-
i
);
if
(
pointer
.
IsValid
())
new
(
schemaRef_
.
template
Push
<
SchemaEntry
>
())
SchemaEntry
(
pointer
,
schema
);
...
...
@@ -977,14 +990,10 @@ private:
}
}
const
SchemaType
*
GetSchema
(
const
GenericPointer
<
ValueType
>&
pointer
)
{
for
(
SchemaEntry
*
target
=
schemaMap_
.
template
Bottom
<
SchemaEntry
>
();
target
<=
schemaMap_
.
template
Top
<
SchemaEntry
>
();
++
target
)
const
SchemaType
*
GetSchema
(
const
PointerType
&
pointer
)
const
{
for
(
const
SchemaEntry
*
target
=
schemaMap_
.
template
Bottom
<
SchemaEntry
>
();
target
!=
schemaMap_
.
template
End
<
SchemaEntry
>
();
++
target
)
if
(
pointer
==
target
->
pointer
)
return
target
->
schema
;
if
(
const
ValueType
*
v
=
pointer
.
Get
(
document_
))
return
CreateSchema
(
pointer
,
*
v
);
else
return
0
;
}
...
...
@@ -1061,7 +1070,7 @@ public:
if (!BeginValue() || !CurrentSchema().method arg1) return valid_ = false;
#define RAPIDJSON_SCHEMA_HANDLE_PARALLEL_(method, arg2)\
for (Context* context = schemaStack_.template Bottom<Context>(); context
<= schemaStack_.template Top
<Context>(); context++) {\
for (Context* context = schemaStack_.template Bottom<Context>(); context
!= schemaStack_.template End
<Context>(); context++) {\
if (context->allOfValidators.validators)\
for (SizeType i_ = 0; i_ < context->allOfValidators.count; i_++)\
static_cast<GenericSchemaValidator*>(context->allOfValidators.validators[i_])->method arg2;\
...
...
test/unittest/schematest.cpp
View file @
3873bcb7
...
...
@@ -763,17 +763,16 @@ public:
}
}
virtual
SchemaDocument
*
GetRemoteDocument
(
const
char
*
uri
,
SizeType
length
)
{
virtual
const
SchemaDocument
*
GetRemoteDocument
(
const
char
*
uri
,
SizeType
length
)
{
const
char
*
uris
[
kCount
]
=
{
"http://localhost:1234/integer.json"
,
"http://localhost:1234/subSchemas.json"
,
"http://localhost:1234/folder/folderInteger.json"
};
for
(
size_t
i
=
0
;
i
<
kCount
;
i
++
)
{
for
(
size_t
i
=
0
;
i
<
kCount
;
i
++
)
if
(
strncmp
(
uri
,
uris
[
i
],
length
)
==
0
)
return
sd_
[
i
];
}
return
0
;
}
...
...
@@ -809,7 +808,7 @@ TEST(SchemaValidator, TestSuite) {
"patternProperties.json"
,
"properties.json"
,
"ref.json"
,
//
"refRemote.json",
"refRemote.json"
,
"required.json"
,
"type.json"
,
//"uniqueItems.json"
...
...
@@ -854,7 +853,7 @@ TEST(SchemaValidator, TestSuite) {
validator
.
Reset
();
bool
actual
=
data
.
Accept
(
validator
);
if
(
expected
!=
actual
)
printf
(
"Fail: %30s
\"
%s
,
%s
\"\n
"
,
filename
,
description1
,
description2
);
printf
(
"Fail: %30s
\"
%s
\"
\"
%s
\"\n
"
,
filename
,
description1
,
description2
);
else
passCount
++
;
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment