aboutsummaryrefslogtreecommitdiffstats
path: root/src/java/org/apache/poi/ss
diff options
context:
space:
mode:
authorGreg Woolsey <gwoolsey@apache.org>2019-03-30 19:33:02 +0000
committerGreg Woolsey <gwoolsey@apache.org>2019-03-30 19:33:02 +0000
commit0d22749477125691ea5c7ca8de620aa5dbdef852 (patch)
tree309fffaa523b03180f69d3691d481865c080a11a /src/java/org/apache/poi/ss
parent30851e44a60a2a9f377eb2f0c938c35bb9fd8f0a (diff)
downloadpoi-0d22749477125691ea5c7ca8de620aa5dbdef852.tar.gz
poi-0d22749477125691ea5c7ca8de620aa5dbdef852.zip
#63291 CellFormat global cache isn't thread-safe
move date format synchronization down to where the problem instance is held. git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1856647 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'src/java/org/apache/poi/ss')
-rw-r--r--src/java/org/apache/poi/ss/format/CellDateFormatter.java2
-rw-r--r--src/java/org/apache/poi/ss/format/CellFormatter.java10
-rw-r--r--src/java/org/apache/poi/ss/usermodel/DataFormatter.java2
3 files changed, 12 insertions, 2 deletions
diff --git a/src/java/org/apache/poi/ss/format/CellDateFormatter.java b/src/java/org/apache/poi/ss/format/CellDateFormatter.java
index b544d9ca16..94a4f46710 100644
--- a/src/java/org/apache/poi/ss/format/CellDateFormatter.java
+++ b/src/java/org/apache/poi/ss/format/CellDateFormatter.java
@@ -163,7 +163,7 @@ public class CellDateFormatter extends CellFormatter {
}
/** {@inheritDoc} */
- public void formatValue(StringBuffer toAppendTo, Object value) {
+ public synchronized void formatValue(StringBuffer toAppendTo, Object value) {
if (value == null)
value = 0.0;
if (value instanceof Number) {
diff --git a/src/java/org/apache/poi/ss/format/CellFormatter.java b/src/java/org/apache/poi/ss/format/CellFormatter.java
index 2803c37e59..3cb7daf179 100644
--- a/src/java/org/apache/poi/ss/format/CellFormatter.java
+++ b/src/java/org/apache/poi/ss/format/CellFormatter.java
@@ -57,6 +57,11 @@ public abstract class CellFormatter {
/**
* Format a value according the format string.
+ * <p/>
+ * NOTE: this method must be thread safe! In particular, if it uses a
+ * Format instance that is not thread safe, i.e. DateFormat, this method
+ * must be synchronized, either on the method, if the format is a final
+ * property, or on the format instance itself.
*
* @param toAppendTo The buffer to append to.
* @param value The value to format.
@@ -65,6 +70,11 @@ public abstract class CellFormatter {
/**
* Format a value according to the type, in the most basic way.
+ * <p/>
+ * NOTE: this method must be thread safe! In particular, if it uses a
+ * Format instance that is not thread safe, i.e. DateFormat, this method
+ * must be synchronized, either on the method, if the format is a final
+ * property, or on the format instance itself.
*
* @param toAppendTo The buffer to append to.
* @param value The value to format.
diff --git a/src/java/org/apache/poi/ss/usermodel/DataFormatter.java b/src/java/org/apache/poi/ss/usermodel/DataFormatter.java
index d80f2bc476..db61f68d44 100644
--- a/src/java/org/apache/poi/ss/usermodel/DataFormatter.java
+++ b/src/java/org/apache/poi/ss/usermodel/DataFormatter.java
@@ -309,7 +309,7 @@ public class DataFormatter implements Observer {
return getFormat(cell.getNumericCellValue(), formatIndex, formatStr);
}
- private synchronized Format getFormat(double cellValue, int formatIndex, String formatStrIn) {
+ private Format getFormat(double cellValue, int formatIndex, String formatStrIn) {
localeChangedObservable.checkForLocaleChange();
// Might be better to separate out the n p and z formats, falling back to p when n and z are not set.