mirror of
https://github.com/qpdf/qpdf.git
synced 2025-01-05 08:02:11 +00:00
Fix json serialization for {x | -1 < x < 1} (fixes #308)
JSON serialization was preserving the value as presented, but JSON doesn't accept decimal values without a 0 before the decimal point.
This commit is contained in:
parent
d2260925f0
commit
da7c2c0ee9
@ -1,3 +1,8 @@
|
|||||||
|
2019-03-11 Jay Berkenbilt <ejb@ql.org>
|
||||||
|
|
||||||
|
* JSON serialization: add missing leading 0 to decimal values
|
||||||
|
between -1 and 1. Fixes #308.
|
||||||
|
|
||||||
2019-02-01 Jay Berkenbilt <ejb@ql.org>
|
2019-02-01 Jay Berkenbilt <ejb@ql.org>
|
||||||
|
|
||||||
* 8.4.0: release
|
* 8.4.0: release
|
||||||
|
@ -25,7 +25,30 @@ QPDF_Real::unparse()
|
|||||||
JSON
|
JSON
|
||||||
QPDF_Real::getJSON()
|
QPDF_Real::getJSON()
|
||||||
{
|
{
|
||||||
return JSON::makeNumber(this->val);
|
// While PDF allows .x or -.x, JSON does not. Rather than
|
||||||
|
// convering from string to double and back, just handle this as a
|
||||||
|
// special case for JSON.
|
||||||
|
std::string result;
|
||||||
|
if (this->val.length() == 0)
|
||||||
|
{
|
||||||
|
// Can't really happen...
|
||||||
|
result = "0";
|
||||||
|
}
|
||||||
|
else if (this->val.at(0) == '.')
|
||||||
|
{
|
||||||
|
result = "0" + this->val;
|
||||||
|
}
|
||||||
|
else if ((this->val.length() >= 2) &&
|
||||||
|
(this->val.at(0) == '-') &&
|
||||||
|
(this->val.at(1) == '.'))
|
||||||
|
{
|
||||||
|
result = "-0." + this->val.substr(2);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
result = this->val;
|
||||||
|
}
|
||||||
|
return JSON::makeNumber(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
QPDFObject::object_type_e
|
QPDFObject::object_type_e
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
|
||||||
static void check(JSON& j, std::string const& exp)
|
static void check(JSON const& j, std::string const& exp)
|
||||||
{
|
{
|
||||||
if (exp != j.unparse())
|
if (exp != j.unparse())
|
||||||
{
|
{
|
||||||
@ -69,6 +69,10 @@ static void test_main()
|
|||||||
" ],\n"
|
" ],\n"
|
||||||
" \"yes\": false\n"
|
" \"yes\": false\n"
|
||||||
"}");
|
"}");
|
||||||
|
check(QPDFObjectHandle::newReal("0.12").getJSON(), "0.12");
|
||||||
|
check(QPDFObjectHandle::newReal(".34").getJSON(), "0.34");
|
||||||
|
check(QPDFObjectHandle::newReal("-0.56").getJSON(), "-0.56");
|
||||||
|
check(QPDFObjectHandle::newReal("-.78").getJSON(), "-0.78");
|
||||||
}
|
}
|
||||||
|
|
||||||
static void check_schema(JSON& obj, JSON& schema, bool exp,
|
static void check_schema(JSON& obj, JSON& schema, bool exp,
|
||||||
|
Loading…
Reference in New Issue
Block a user