2018-12-06 23:28:13 +01:00
|
|
|
--- fop-2.1/src/java/org/apache/fop/afp/fonts/CharactersetEncoder.java 2016-01-07 15:13:29.000000000 +0100
|
|
|
|
+++ fop-2.1/src/java/org/apache/fop/afp/fonts/CharactersetEncoder.java 2018-12-06 23:18:14.815791853 +0100
|
|
|
|
@@ -21,6 +21,7 @@
|
|
|
|
|
|
|
|
import java.io.IOException;
|
|
|
|
import java.io.OutputStream;
|
|
|
|
+import java.nio.Buffer;
|
|
|
|
import java.nio.ByteBuffer;
|
|
|
|
import java.nio.CharBuffer;
|
|
|
|
import java.nio.charset.CharacterCodingException;
|
|
|
|
@@ -68,7 +69,7 @@
|
|
|
|
if (bb.hasArray()) {
|
|
|
|
return getEncodedChars(bb.array(), bb.limit());
|
|
|
|
} else {
|
|
|
|
- bb.rewind();
|
|
|
|
+ ((Buffer)bb).rewind();
|
|
|
|
byte[] bytes = new byte[bb.remaining()];
|
|
|
|
bb.get(bytes);
|
|
|
|
return getEncodedChars(bytes, bytes.length);
|
|
|
|
--- fop-2.1/src/java/org/apache/fop/area/AreaTreeParser.java 2016-01-07 15:13:29.000000000 +0100
|
|
|
|
+++ fop-2.1/src/java/org/apache/fop/area/AreaTreeParser.java 2018-12-06 23:18:14.815791853 +0100
|
|
|
|
@@ -24,6 +24,7 @@
|
|
|
|
import java.awt.geom.Rectangle2D;
|
|
|
|
import java.io.FileNotFoundException;
|
|
|
|
import java.io.IOException;
|
|
|
|
+import java.nio.Buffer;
|
|
|
|
import java.nio.CharBuffer;
|
|
|
|
import java.util.List;
|
|
|
|
import java.util.Map;
|
|
|
|
@@ -322,7 +323,7 @@
|
|
|
|
throws SAXException {
|
|
|
|
lastAttributes = new AttributesImpl(attributes);
|
|
|
|
Maker maker = makers.get(localName);
|
|
|
|
- content.clear();
|
|
|
|
+ ((Buffer)content).clear();
|
|
|
|
ignoreCharacters = true;
|
|
|
|
if (maker != null) {
|
|
|
|
ignoreCharacters = maker.ignoreCharacters();
|
|
|
|
@@ -353,7 +354,7 @@
|
|
|
|
Maker maker = makers.get(localName);
|
|
|
|
if (maker != null) {
|
|
|
|
maker.endElement();
|
|
|
|
- content.clear();
|
|
|
|
+ ((Buffer)content).clear();
|
|
|
|
}
|
|
|
|
ignoreCharacters = true;
|
|
|
|
} else {
|
|
|
|
@@ -798,7 +799,7 @@
|
|
|
|
boolean reversed = XMLUtil.getAttributeAsBoolean(lastAttributes, "reversed", false);
|
|
|
|
int[][] gposAdjustments
|
|
|
|
= XMLUtil.getAttributeAsPositionAdjustments(lastAttributes, "position-adjust");
|
|
|
|
- content.flip();
|
|
|
|
+ ((Buffer)content).flip();
|
|
|
|
WordArea word = new WordArea(
|
|
|
|
offset, level, content.toString().trim(), letterAdjust,
|
|
|
|
null, gposAdjustments, reversed);
|
|
|
|
@@ -818,7 +819,7 @@
|
|
|
|
int offset = XMLUtil.getAttributeAsInt(lastAttributes, "offset", 0);
|
|
|
|
//TODO the isAdjustable parameter is currently not used/implemented
|
|
|
|
if (content.position() > 0) {
|
|
|
|
- content.flip();
|
|
|
|
+ ((Buffer)content).flip();
|
|
|
|
boolean adjustable = XMLUtil.getAttributeAsBoolean(lastAttributes, "adj", true);
|
|
|
|
int level = XMLUtil.getAttributeAsInt(lastAttributes, "level", -1);
|
|
|
|
SpaceArea space = new SpaceArea(offset, level, content.charAt(0), adjustable);
|
|
|
|
@@ -1207,17 +1208,17 @@
|
|
|
|
// allocate a larger buffer and transfer content
|
|
|
|
CharBuffer newContent
|
|
|
|
= CharBuffer.allocate(this.content.position() + length);
|
|
|
|
- this.content.flip();
|
|
|
|
+ ((Buffer)(this.content)).flip();
|
|
|
|
newContent.put(this.content);
|
|
|
|
this.content = newContent;
|
|
|
|
}
|
|
|
|
// make sure the full capacity is used
|
|
|
|
- this.content.limit(this.content.capacity());
|
|
|
|
+ ((Buffer)(this.content)).limit(this.content.capacity());
|
|
|
|
// add characters to the buffer
|
|
|
|
this.content.put(ch, start, length);
|
|
|
|
// decrease the limit, if necessary
|
|
|
|
if (this.content.position() < this.content.limit()) {
|
|
|
|
- this.content.limit(this.content.position());
|
|
|
|
+ ((Buffer)(this.content)).limit(this.content.position());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2018-04-05 12:14:35 +02:00
|
|
|
--- fop-2.1/src/java/org/apache/fop/fo/FOText.java 2016-01-07 15:13:29.000000000 +0100
|
2018-12-06 23:28:13 +01:00
|
|
|
+++ fop-2.1/src/java/org/apache/fop/fo/FOText.java 2018-12-06 23:21:33.412845154 +0100
|
2018-04-05 12:14:35 +02:00
|
|
|
@@ -20,6 +20,7 @@
|
|
|
|
package org.apache.fop.fo;
|
|
|
|
|
|
|
|
import java.awt.Color;
|
|
|
|
+import java.nio.Buffer;
|
|
|
|
import java.nio.CharBuffer;
|
|
|
|
import java.text.CharacterIterator;
|
|
|
|
import java.text.StringCharacterIterator;
|
2018-12-06 23:28:13 +01:00
|
|
|
@@ -128,17 +129,17 @@
|
|
|
|
newCapacity = requires;
|
|
|
|
}
|
|
|
|
CharBuffer newBuffer = CharBuffer.allocate(newCapacity);
|
|
|
|
- charBuffer.rewind();
|
|
|
|
+ ((Buffer)charBuffer).rewind();
|
|
|
|
newBuffer.put(charBuffer);
|
|
|
|
charBuffer = newBuffer;
|
2018-04-05 12:14:35 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
// extend limit to capacity
|
|
|
|
- charBuffer.limit(charBuffer.capacity());
|
|
|
|
+ ((Buffer)charBuffer).limit(charBuffer.capacity());
|
|
|
|
// append characters
|
|
|
|
charBuffer.put(data, start, length);
|
|
|
|
// shrink limit to position
|
|
|
|
- charBuffer.limit(charBuffer.position());
|
|
|
|
+ ((Buffer)charBuffer).limit(((Buffer)charBuffer).position());
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2018-12-06 23:28:13 +01:00
|
|
|
@@ -150,7 +151,7 @@
|
|
|
|
if (this.charBuffer == null) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
- this.charBuffer.rewind();
|
|
|
|
+ ((Buffer)(this.charBuffer)).rewind();
|
|
|
|
return this.charBuffer.asReadOnlyBuffer().subSequence(0, this.charBuffer.limit());
|
|
|
|
}
|
|
|
|
|
|
|
|
@@ -163,9 +164,9 @@
|
2018-04-05 12:14:35 +02:00
|
|
|
// pointed to is really a different one
|
|
|
|
if (charBuffer != null) {
|
2018-12-06 23:28:13 +01:00
|
|
|
ft.charBuffer = CharBuffer.allocate(charBuffer.limit());
|
|
|
|
- charBuffer.rewind();
|
|
|
|
+ ((Buffer)charBuffer).rewind();
|
2018-04-05 12:14:35 +02:00
|
|
|
ft.charBuffer.put(charBuffer);
|
2018-12-06 23:28:13 +01:00
|
|
|
- ft.charBuffer.rewind();
|
|
|
|
+ ((Buffer)(ft.charBuffer)).rewind();
|
|
|
|
}
|
2018-04-05 12:14:35 +02:00
|
|
|
}
|
2018-12-06 23:28:13 +01:00
|
|
|
ft.prevFOTextThisBlock = null;
|
|
|
|
@@ -197,7 +198,7 @@
|
|
|
|
/** {@inheritDoc} */
|
|
|
|
public void endOfNode() throws FOPException {
|
|
|
|
if (charBuffer != null) {
|
|
|
|
- charBuffer.rewind();
|
|
|
|
+ ((Buffer)charBuffer).rewind();
|
|
|
|
}
|
|
|
|
super.endOfNode();
|
|
|
|
getFOEventHandler().characters(this);
|
|
|
|
@@ -224,7 +225,7 @@
|
2018-04-05 12:14:35 +02:00
|
|
|
}
|
|
|
|
|
2018-12-06 23:28:13 +01:00
|
|
|
char ch;
|
|
|
|
- charBuffer.rewind();
|
|
|
|
+ ((Buffer)charBuffer).rewind();
|
|
|
|
while (charBuffer.hasRemaining()) {
|
|
|
|
ch = charBuffer.get();
|
|
|
|
if (!((ch == CharUtilities.SPACE)
|
|
|
|
@@ -232,7 +233,7 @@
|
|
|
|
|| (ch == CharUtilities.CARRIAGE_RETURN)
|
|
|
|
|| (ch == CharUtilities.TAB))) {
|
|
|
|
// not whitespace
|
|
|
|
- charBuffer.rewind();
|
|
|
|
+ ((Buffer)charBuffer).rewind();
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
@@ -275,7 +276,7 @@
|
|
|
|
return;
|
|
|
|
}
|
2018-04-05 12:14:35 +02:00
|
|
|
|
2018-12-06 23:28:13 +01:00
|
|
|
- charBuffer.rewind();
|
|
|
|
+ ((Buffer)charBuffer).rewind();
|
|
|
|
CharBuffer tmp = charBuffer.slice();
|
|
|
|
char c;
|
|
|
|
int lim = charBuffer.limit();
|
|
|
|
@@ -542,19 +543,19 @@
|
2018-04-05 12:14:35 +02:00
|
|
|
public void remove() {
|
|
|
|
|
|
|
|
if (this.canRemove) {
|
|
|
|
- charBuffer.position(currentPosition);
|
|
|
|
+ ((Buffer)charBuffer).position(currentPosition);
|
|
|
|
// Slice the buffer at the current position
|
|
|
|
CharBuffer tmp = charBuffer.slice();
|
|
|
|
// Reset position to before current character
|
|
|
|
- charBuffer.position(--currentPosition);
|
|
|
|
+ ((Buffer)charBuffer).position(--currentPosition);
|
|
|
|
if (tmp.hasRemaining()) {
|
|
|
|
// Transfer any remaining characters
|
2018-12-06 23:28:13 +01:00
|
|
|
- charBuffer.mark();
|
|
|
|
+ ((Buffer)charBuffer).mark();
|
|
|
|
charBuffer.put(tmp);
|
|
|
|
- charBuffer.reset();
|
|
|
|
+ ((Buffer)charBuffer).reset();
|
2018-04-05 12:14:35 +02:00
|
|
|
}
|
|
|
|
// Decrease limit
|
|
|
|
- charBuffer.limit(charBuffer.limit() - 1);
|
|
|
|
+ ((Buffer)charBuffer).limit(((Buffer)charBuffer).limit() - 1);
|
|
|
|
// Make sure following calls fail, unless nextChar() was called
|
|
|
|
this.canRemove = false;
|
|
|
|
} else {
|
2018-12-06 23:28:13 +01:00
|
|
|
@@ -737,7 +738,7 @@
|
|
|
|
*/
|
|
|
|
public void resetBuffer() {
|
|
|
|
if (charBuffer != null) {
|
|
|
|
- charBuffer.rewind();
|
|
|
|
+ ((Buffer)charBuffer).rewind();
|
|
|
|
}
|
|
|
|
}
|
2018-04-05 12:14:35 +02:00
|
|
|
|
2018-12-06 23:28:13 +01:00
|
|
|
--- fop-2.1/src/java/org/apache/fop/fonts/MultiByteFont.java 2016-01-07 15:13:29.000000000 +0100
|
|
|
|
+++ fop-2.1/src/java/org/apache/fop/fonts/MultiByteFont.java 2018-12-06 23:18:14.815791853 +0100
|
|
|
|
@@ -21,6 +21,7 @@
|
|
|
|
|
|
|
|
import java.awt.Rectangle;
|
|
|
|
import java.io.InputStream;
|
|
|
|
+import java.nio.Buffer;
|
|
|
|
import java.nio.CharBuffer;
|
|
|
|
import java.nio.IntBuffer;
|
|
|
|
import java.util.BitSet;
|
|
|
|
@@ -686,7 +687,7 @@
|
|
|
|
cb.put((char) cc);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
- cb.flip();
|
|
|
|
+ ((Buffer)cb).flip();
|
|
|
|
return cb;
|
2018-04-05 12:14:35 +02:00
|
|
|
}
|
|
|
|
|