aboutsummaryrefslogtreecommitdiffstats
path: root/libqpdf/QPDFAcroFormDocumentHelper.cc
diff options
context:
space:
mode:
authorJay Berkenbilt <ejb@ql.org>2018-06-21 21:00:00 +0200
committerJay Berkenbilt <ejb@ql.org>2018-06-21 21:57:13 +0200
commit397b097c469db89a49e5a6c2035a0beee2e4d117 (patch)
tree5f2b5e33be51922d210146dd78a1e4a66749691d /libqpdf/QPDFAcroFormDocumentHelper.cc
parent952a665a4ed51400b5925e7cd69f08f0aeb374fe (diff)
downloadqpdf-397b097c469db89a49e5a6c2035a0beee2e4d117.tar.zst
Allow setting a form field's value
Diffstat (limited to 'libqpdf/QPDFAcroFormDocumentHelper.cc')
-rw-r--r--libqpdf/QPDFAcroFormDocumentHelper.cc35
1 files changed, 35 insertions, 0 deletions
diff --git a/libqpdf/QPDFAcroFormDocumentHelper.cc b/libqpdf/QPDFAcroFormDocumentHelper.cc
index 7e70fd92..46648ed9 100644
--- a/libqpdf/QPDFAcroFormDocumentHelper.cc
+++ b/libqpdf/QPDFAcroFormDocumentHelper.cc
@@ -250,3 +250,38 @@ QPDFAcroFormDocumentHelper::traverseField(
QPDFFormFieldObjectHelper(our_field);
}
}
+
+bool
+QPDFAcroFormDocumentHelper::getNeedAppearances()
+{
+ bool result = false;
+ QPDFObjectHandle acroform = this->qpdf.getRoot().getKey("/AcroForm");
+ if (acroform.isDictionary() &&
+ acroform.getKey("/NeedAppearances").isBool())
+ {
+ result = acroform.getKey("/NeedAppearances").getBoolValue();
+ }
+ return result;
+}
+
+void
+QPDFAcroFormDocumentHelper::setNeedAppearances(bool val)
+{
+ QPDFObjectHandle acroform = this->qpdf.getRoot().getKey("/AcroForm");
+ if (! acroform.isDictionary())
+ {
+ this->qpdf.getRoot().warnIfPossible(
+ "ignoring call to QPDFAcroFormDocumentHelper::setNeedAppearances"
+ " on a file that lacks an /AcroForm dictionary");
+ return;
+ }
+ if (val)
+ {
+ acroform.replaceKey("/NeedAppearances",
+ QPDFObjectHandle::newBool(true));
+ }
+ else
+ {
+ acroform.removeKey("/NeedAppearances");
+ }
+}