aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorNick Burch <nick@apache.org>2015-08-11 20:01:26 +0000
committerNick Burch <nick@apache.org>2015-08-11 20:01:26 +0000
commit3aa84d4555ff73ee44302e9a4c8cd35f7cef2dd8 (patch)
tree08b5e4acda56c1272b8c4390640d9110736eb918 /src
parent574cd922f446be82d66f364b4ad8229bc4dbb51c (diff)
downloadpoi-3aa84d4555ff73ee44302e9a4c8cd35f7cef2dd8.tar.gz
poi-3aa84d4555ff73ee44302e9a4c8cd35f7cef2dd8.zip
Support XWPF field runs, the same way that we handle hyperlink runs
git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1695361 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'src')
-rw-r--r--src/ooxml/java/org/apache/poi/xwpf/usermodel/XWPFFieldRun.java48
-rw-r--r--src/ooxml/java/org/apache/poi/xwpf/usermodel/XWPFHyperlinkRun.java4
-rw-r--r--src/ooxml/java/org/apache/poi/xwpf/usermodel/XWPFParagraph.java17
-rw-r--r--src/ooxml/testcases/org/apache/poi/xwpf/usermodel/TestXWPFParagraph.java19
4 files changed, 79 insertions, 9 deletions
diff --git a/src/ooxml/java/org/apache/poi/xwpf/usermodel/XWPFFieldRun.java b/src/ooxml/java/org/apache/poi/xwpf/usermodel/XWPFFieldRun.java
new file mode 100644
index 0000000000..997c7d0cb3
--- /dev/null
+++ b/src/ooxml/java/org/apache/poi/xwpf/usermodel/XWPFFieldRun.java
@@ -0,0 +1,48 @@
+/* ====================================================================
+ Licensed to the Apache Software Foundation (ASF) under one or more
+ contributor license agreements. See the NOTICE file distributed with
+ this work for additional information regarding copyright ownership.
+ The ASF licenses this file to You under the Apache License, Version 2.0
+ (the "License"); you may not use this file except in compliance with
+ the License. You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+==================================================================== */
+package org.apache.poi.xwpf.usermodel;
+
+import org.apache.poi.util.Internal;
+import org.openxmlformats.schemas.wordprocessingml.x2006.main.CTR;
+import org.openxmlformats.schemas.wordprocessingml.x2006.main.CTSimpleField;
+
+/**
+ * A run of text which is part of a field, such as Title
+ * of Page number or Author.
+ * Any given Field may be made up of multiple of these.
+ */
+public class XWPFFieldRun extends XWPFRun {
+ private CTSimpleField field;
+
+ public XWPFFieldRun(CTSimpleField field, CTR run, IRunBody p) {
+ super(run, p);
+ this.field = field;
+ }
+
+ @Internal
+ public CTSimpleField getCTField() {
+ return field;
+ }
+
+ public String getFieldInstruction() {
+ return field.getInstr();
+ }
+
+ public void setFieldInstruction(String instruction) {
+ field.setInstr(instruction);
+ }
+}
diff --git a/src/ooxml/java/org/apache/poi/xwpf/usermodel/XWPFHyperlinkRun.java b/src/ooxml/java/org/apache/poi/xwpf/usermodel/XWPFHyperlinkRun.java
index 4c8158a411..9a79b20f0f 100644
--- a/src/ooxml/java/org/apache/poi/xwpf/usermodel/XWPFHyperlinkRun.java
+++ b/src/ooxml/java/org/apache/poi/xwpf/usermodel/XWPFHyperlinkRun.java
@@ -16,6 +16,7 @@
==================================================================== */
package org.apache.poi.xwpf.usermodel;
+import org.apache.poi.util.Internal;
import org.openxmlformats.schemas.wordprocessingml.x2006.main.CTHyperlink;
import org.openxmlformats.schemas.wordprocessingml.x2006.main.CTR;
@@ -30,7 +31,8 @@ public class XWPFHyperlinkRun extends XWPFRun {
super(run, p);
this.hyperlink = hyperlink;
}
-
+
+ @Internal
public CTHyperlink getCTHyperlink() {
return hyperlink;
}
diff --git a/src/ooxml/java/org/apache/poi/xwpf/usermodel/XWPFParagraph.java b/src/ooxml/java/org/apache/poi/xwpf/usermodel/XWPFParagraph.java
index 0eae922479..65c726d102 100644
--- a/src/ooxml/java/org/apache/poi/xwpf/usermodel/XWPFParagraph.java
+++ b/src/ooxml/java/org/apache/poi/xwpf/usermodel/XWPFParagraph.java
@@ -142,13 +142,21 @@ public class XWPFParagraph implements IBodyElement, IRunBody, ISDTContents, Para
iruns.add(r);
}
if (o instanceof CTHyperlink) {
- CTHyperlink link = (CTHyperlink) o;
+ CTHyperlink link = (CTHyperlink)o;
for (CTR r : link.getRArray()) {
XWPFHyperlinkRun hr = new XWPFHyperlinkRun(link, r, this);
runs.add(hr);
iruns.add(hr);
}
}
+ if (o instanceof CTSimpleField) {
+ CTSimpleField field = (CTSimpleField)o;
+ for (CTR r : field.getRArray()) {
+ XWPFFieldRun fr = new XWPFFieldRun(field, r, this);
+ runs.add(fr);
+ iruns.add(fr);
+ }
+ }
if (o instanceof CTSdtBlock) {
XWPFSDT cc = new XWPFSDT((CTSdtBlock) o, part);
iruns.add(cc);
@@ -164,13 +172,6 @@ public class XWPFParagraph implements IBodyElement, IRunBody, ISDTContents, Para
iruns.add(cr);
}
}
- if (o instanceof CTSimpleField) {
- for (CTR r : ((CTSimpleField) o).getRArray()) {
- XWPFRun cr = new XWPFRun(r, this);
- runs.add(cr);
- iruns.add(cr);
- }
- }
if (o instanceof CTSmartTagRun) {
// Smart Tags can be nested many times.
// This implementation does not preserve the tagging information
diff --git a/src/ooxml/testcases/org/apache/poi/xwpf/usermodel/TestXWPFParagraph.java b/src/ooxml/testcases/org/apache/poi/xwpf/usermodel/TestXWPFParagraph.java
index 31be821e06..f53d524b01 100644
--- a/src/ooxml/testcases/org/apache/poi/xwpf/usermodel/TestXWPFParagraph.java
+++ b/src/ooxml/testcases/org/apache/poi/xwpf/usermodel/TestXWPFParagraph.java
@@ -22,6 +22,7 @@ import java.math.BigInteger;
import java.util.List;
import junit.framework.TestCase;
+
import org.apache.poi.xwpf.XWPFTestDataSamples;
import org.openxmlformats.schemas.drawingml.x2006.picture.CTPicture;
import org.openxmlformats.schemas.drawingml.x2006.picture.PicDocument;
@@ -495,6 +496,24 @@ public final class TestXWPFParagraph extends TestCase {
assertTrue(p.removeRun(0));
}
+
+ public void testFieldRuns() throws Exception {
+ XWPFDocument doc = XWPFTestDataSamples.openSampleDocument("FldSimple.docx");
+ List<XWPFParagraph> ps = doc.getParagraphs();
+ assertEquals(1, ps.size());
+
+ XWPFParagraph p = ps.get(0);
+ assertEquals(1, p.getRuns().size());
+ assertEquals(1, p.getIRuns().size());
+
+ XWPFRun r = p.getRuns().get(0);
+ assertEquals(XWPFFieldRun.class, r.getClass());
+
+ XWPFFieldRun fr = (XWPFFieldRun)r;
+ assertEquals(" FILENAME \\* MERGEFORMAT ", fr.getFieldInstruction());
+ assertEquals("FldSimple.docx", fr.text());
+ assertEquals("FldSimple.docx", p.getText());
+ }
@SuppressWarnings("deprecation")
public void testRuns() {