aboutsummaryrefslogtreecommitdiffstats
path: root/src/ooxml/java/org/apache/poi
diff options
context:
space:
mode:
authorAndreas Beeker <kiwiwings@apache.org>2020-04-01 23:23:55 +0000
committerAndreas Beeker <kiwiwings@apache.org>2020-04-01 23:23:55 +0000
commitefd9c7c277c14561723e49e4071f705c99109fe6 (patch)
tree4fb02261791f65320a9bace8d5cd551007f85ce4 /src/ooxml/java/org/apache/poi
parentd383fea7bda86630c8fe44508c7f1c65c2af3b83 (diff)
downloadpoi-efd9c7c277c14561723e49e4071f705c99109fe6.tar.gz
poi-efd9c7c277c14561723e49e4071f705c99109fe6.zip
#64301 - Allow try-with-resources with OPCPackage.revert()
git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1876018 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'src/ooxml/java/org/apache/poi')
-rw-r--r--src/ooxml/java/org/apache/poi/openxml4j/opc/OPCPackage.java40
-rw-r--r--src/ooxml/java/org/apache/poi/openxml4j/opc/ZipPackage.java7
2 files changed, 34 insertions, 13 deletions
diff --git a/src/ooxml/java/org/apache/poi/openxml4j/opc/OPCPackage.java b/src/ooxml/java/org/apache/poi/openxml4j/opc/OPCPackage.java
index 28ac90f7bb..39ff11fa30 100644
--- a/src/ooxml/java/org/apache/poi/openxml4j/opc/OPCPackage.java
+++ b/src/ooxml/java/org/apache/poi/openxml4j/opc/OPCPackage.java
@@ -32,11 +32,16 @@ import java.io.InputStream;
import java.io.OutputStream;
import java.net.URI;
import java.net.URISyntaxException;
-import java.util.*;
+import java.util.ArrayList;
+import java.util.Collections;
+import java.util.Date;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.Optional;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
-import org.apache.poi.ooxml.util.PackageHelper;
import org.apache.poi.openxml4j.exceptions.InvalidFormatException;
import org.apache.poi.openxml4j.exceptions.InvalidOperationException;
import org.apache.poi.openxml4j.exceptions.OpenXML4JRuntimeException;
@@ -210,7 +215,7 @@ public abstract class OPCPackage implements RelationshipSource, Closeable {
throw e;
}
}
-
+
/**
* Open a package.
*
@@ -230,7 +235,7 @@ public abstract class OPCPackage implements RelationshipSource, Closeable {
if (path == null || path.trim().isEmpty()) {
throw new IllegalArgumentException("'path' must be given");
}
-
+
File file = new File(path);
if (file.exists() && file.isDirectory()) {
throw new IllegalArgumentException("path must not be a directory");
@@ -383,7 +388,7 @@ public abstract class OPCPackage implements RelationshipSource, Closeable {
try {
// Content type manager
pkg.contentTypeManager = new ZipContentTypeManager(null, pkg);
-
+
// Add default content types for .xml and .rels
pkg.contentTypeManager.addContentType(
PackagingURIHelper.createPartName(
@@ -421,7 +426,7 @@ public abstract class OPCPackage implements RelationshipSource, Closeable {
/**
* Close the open, writable package and save its content.
- *
+ *
* If your package is open read only, then you should call {@link #revert()}
* when finished with the package.
*
@@ -432,8 +437,12 @@ public abstract class OPCPackage implements RelationshipSource, Closeable {
*/
@Override
public void close() throws IOException {
+ if (isClosed()) {
+ return;
+ }
+
if (this.packageAccess == PackageAccess.READ) {
- logger.log(POILogger.WARN,
+ logger.log(POILogger.WARN,
"The close() method is intended to SAVE a package. This package is open in READ ONLY mode, use the revert() method instead !");
revert();
return;
@@ -707,11 +716,11 @@ public abstract class OPCPackage implements RelationshipSource, Closeable {
/**
* Load the parts of the archive if it has not been done yet. The
* relationships of each part are not loaded.
- *
+ *
* Note - Rule M4.1 states that there may only ever be one Core
* Properties Part, but Office produced files will sometimes
* have multiple! As Office ignores all but the first, we relax
- * Compliance with Rule M4.1, and ignore all others silently too.
+ * Compliance with Rule M4.1, and ignore all others silently too.
*
* @return All this package's parts.
* @throws InvalidFormatException if the package is not valid.
@@ -1477,16 +1486,16 @@ public abstract class OPCPackage implements RelationshipSource, Closeable {
}
this.throwExceptionIfReadOnly();
-
+
// You shouldn't save the the same file, do a close instead
- if(targetFile.exists() &&
+ if(targetFile.exists() &&
targetFile.getAbsolutePath().equals(this.originalPackagePath)) {
throw new InvalidOperationException(
"You can't call save(File) to save to the currently open " +
"file. To save to the current file, please just call close()"
);
}
-
+
// Do the save
try (FileOutputStream fos = new FileOutputStream(targetFile)) {
this.save(fos);
@@ -1649,9 +1658,14 @@ public abstract class OPCPackage implements RelationshipSource, Closeable {
* e.g. "/ppt/slides/slide#.xml"
* @return the next available part name index
* @throws InvalidFormatException if the nameTemplate is null or doesn't contain
- * the index char (#) or results in an invalid part name
+ * the index char (#) or results in an invalid part name
*/
public int getUnusedPartIndex(final String nameTemplate) throws InvalidFormatException {
return partList.getUnusedPartIndex(nameTemplate);
}
+
+ /**
+ * Has close been called already?
+ */
+ public abstract boolean isClosed();
}
diff --git a/src/ooxml/java/org/apache/poi/openxml4j/opc/ZipPackage.java b/src/ooxml/java/org/apache/poi/openxml4j/opc/ZipPackage.java
index 5cd3a14598..2520ba4378 100644
--- a/src/ooxml/java/org/apache/poi/openxml4j/opc/ZipPackage.java
+++ b/src/ooxml/java/org/apache/poi/openxml4j/opc/ZipPackage.java
@@ -564,4 +564,11 @@ public final class ZipPackage extends OPCPackage {
public ZipEntrySource getZipArchive() {
return zipArchive;
}
+
+ @Override
+ public boolean isClosed() {
+ // if zipArchive == null, it might be created on the fly
+ // so only return true, if a zip archive was initialized before
+ return zipArchive != null && zipArchive.isClosed();
+ }
}