aboutsummaryrefslogtreecommitdiffstats
path: root/libqpdf/QPDFFormFieldObjectHelper.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/QPDFFormFieldObjectHelper.cc
parent952a665a4ed51400b5925e7cd69f08f0aeb374fe (diff)
downloadqpdf-397b097c469db89a49e5a6c2035a0beee2e4d117.tar.zst
Allow setting a form field's value
Diffstat (limited to 'libqpdf/QPDFFormFieldObjectHelper.cc')
-rw-r--r--libqpdf/QPDFFormFieldObjectHelper.cc42
1 files changed, 42 insertions, 0 deletions
diff --git a/libqpdf/QPDFFormFieldObjectHelper.cc b/libqpdf/QPDFFormFieldObjectHelper.cc
index e6445af3..283b632d 100644
--- a/libqpdf/QPDFFormFieldObjectHelper.cc
+++ b/libqpdf/QPDFFormFieldObjectHelper.cc
@@ -1,5 +1,6 @@
#include <qpdf/QPDFFormFieldObjectHelper.hh>
#include <qpdf/QTC.hh>
+#include <qpdf/QPDFAcroFormDocumentHelper.hh>
QPDFFormFieldObjectHelper::Members::~Members()
{
@@ -188,3 +189,44 @@ QPDFFormFieldObjectHelper::getQuadding()
}
return result;
}
+
+void
+QPDFFormFieldObjectHelper::setFieldAttribute(
+ std::string const& key, QPDFObjectHandle value)
+{
+ this->oh.replaceKey(key, value);
+}
+
+void
+QPDFFormFieldObjectHelper::setFieldAttribute(
+ std::string const& key, std::string const& utf8_value)
+{
+ this->oh.replaceKey(key, QPDFObjectHandle::newUnicodeString(utf8_value));
+}
+
+void
+QPDFFormFieldObjectHelper::setV(
+ QPDFObjectHandle value, bool need_appearances)
+{
+ setFieldAttribute("/V", value);
+ if (need_appearances)
+ {
+ QPDF* qpdf = this->oh.getOwningQPDF();
+ if (! qpdf)
+ {
+ throw std::logic_error(
+ "QPDFFormFieldObjectHelper::setV called with"
+ " need_appearances = true on an object that is"
+ " not associated with an owning QPDF");
+ }
+ QPDFAcroFormDocumentHelper(*qpdf).setNeedAppearances(true);
+ }
+}
+
+void
+QPDFFormFieldObjectHelper::setV(
+ std::string const& utf8_value, bool need_appearances)
+{
+ setV(QPDFObjectHandle::newUnicodeString(utf8_value),
+ need_appearances);
+}