Allow serialization values to mark themselves as _default.

Solves unnecessarily serialized leading values.
This commit is contained in:
Jürg Lehni 2013-10-17 11:47:46 +02:00
parent efe8bab129
commit 1eb6b49e8a
2 changed files with 12 additions and 2 deletions

View file

@ -164,12 +164,16 @@ var Item = Base.extend(Callback, /** @lends Item# */{
function serialize(fields) { function serialize(fields) {
for (var key in fields) { for (var key in fields) {
var value = that[key]; var value = that[key];
if (!Base.equals(value, fields[key])) // Allow returned values to mark themselves as default through
// the "hidden" _default property. See Style#getLeading()
if (!(value && value._default)
&& !Base.equals(value, fields[key])) {
props[key] = Base.serialize(value, options, props[key] = Base.serialize(value, options,
// Do not use compact mode for data // Do not use compact mode for data
key !== 'data', dictionary); key !== 'data', dictionary);
} }
} }
}
// Serialize fields that this Item subclass defines first // Serialize fields that this Item subclass defines first
serialize(this._serializeFields); serialize(this._serializeFields);

View file

@ -238,7 +238,13 @@ var Style = Base.extend(new function() {
getLeading: function getLeading() { getLeading: function getLeading() {
// Override leading to return fontSize * 1.2 by default. // Override leading to return fontSize * 1.2 by default.
var leading = getLeading.base.call(this); var leading = getLeading.base.call(this);
return leading != null ? leading : this.getFontSize() * 1.2; if (leading == null) {
// Box default leading in a Number, and mark it as default, for
// serialization.
leading = new Number(this.getFontSize() * 1.2);
leading._default = true;
}
return leading;
}, },
getFontStyle: function() { getFontStyle: function() {