XFA - Add a missing method to XFAAttribute, to prevent breaking errors (issue 13748)

*This is yet another case where I've got no idea if the patch is correct, but it does at least fix a breaking error :-)*

Note how in the [`Binder._bindValue` method](683ce66a48/src/core/xfa/bind.js (L92-L93)), we're assuming that if a `data`-value exists then it'll also be possible to actually access it. For the `XFAAttribute`-implementation however, the second method is missing and that's what causes the breaking errors in issue 13748.

Please note that another possible way of "fixing" the error wouldn't been to simply change the exists-check to return `false`, and I could see that being a preferred solution.
However, the reason for submitting the current patch is that we get *fewer* warnings about Nodes with mis-matched types this way.
This commit is contained in:
Jonas Jenwald 2021-07-20 17:14:20 +02:00
parent 683ce66a48
commit c2fe493abe
3 changed files with 14 additions and 0 deletions

View File

@ -745,6 +745,10 @@ class XFAAttribute {
return true;
}
[$getDataValue]() {
return this[$content].trim();
}
[$setValue](value) {
value = value.value || "";
this[$content] = value.toString();

View File

@ -0,0 +1 @@
https://github.com/mozilla/pdf.js/files/6849364/IFT-3R.7._v1-1E.pdf

View File

@ -1347,6 +1347,15 @@
"link": false,
"type": "eq"
},
{ "id": "issue13748",
"file": "pdfs/issue13748.pdf",
"md5": "de0e4dde2890b9ff145a3184831bae02",
"link": true,
"rounds": 1,
"lastPage": 1,
"enableXfa": true,
"type": "eq"
},
{ "id": "issue13756",
"file": "pdfs/issue13756.pdf",
"md5": "67040c6df3b5039fcbc81bf63b7c7f98",