aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/java/org/apache/fop/fonts/MultiByteFont.java5
-rw-r--r--src/java/org/apache/fop/fonts/truetype/TTFFile.java9
-rw-r--r--src/java/org/apache/fop/pdf/PDFToUnicodeCMap.java109
3 files changed, 57 insertions, 66 deletions
diff --git a/src/java/org/apache/fop/fonts/MultiByteFont.java b/src/java/org/apache/fop/fonts/MultiByteFont.java
index 6db84b68d..bcb295741 100644
--- a/src/java/org/apache/fop/fonts/MultiByteFont.java
+++ b/src/java/org/apache/fop/fonts/MultiByteFont.java
@@ -306,14 +306,15 @@ public class MultiByteFont extends CIDFont {
* that need to return an invalid character. */
public static final char INVALID_UNICODE_CHAR = 0xFFFF;
+ /** @see org.apache.fop.fonts.CIDFont#getCharsUsed() */
public char[] getCharsUsed() {
- if (! isEmbeddable()) {
+ if (!isEmbeddable()) {
return null;
}
char[] charArray = new char[usedGlyphsCount];
for (int i = 0; i < usedGlyphsCount; i++) {
Integer mapValue = (Integer)usedCharsIndex.get(new Integer(i));
- if(mapValue != null) {
+ if (mapValue != null) {
char arrayItem = (char) mapValue.intValue();
charArray[i] = arrayItem;
}
diff --git a/src/java/org/apache/fop/fonts/truetype/TTFFile.java b/src/java/org/apache/fop/fonts/truetype/TTFFile.java
index 9288486a4..bd7f8276b 100644
--- a/src/java/org/apache/fop/fonts/truetype/TTFFile.java
+++ b/src/java/org/apache/fop/fonts/truetype/TTFFile.java
@@ -933,8 +933,9 @@ public class TTFFile {
*/
protected final void readIndexToLocation(FontFileReader in)
throws IOException {
- if(!seekTab(in, "loca", 0)) {
- throw new IOException("'loca' table not found, happens when the font file doesn't contain TrueType outlines (trying to read an OpenType CFF font maybe?)");
+ if (!seekTab(in, "loca", 0)) {
+ throw new IOException("'loca' table not found, happens when the font file doesn't"
+ + " contain TrueType outlines (trying to read an OpenType CFF font maybe?)");
}
for (int i = 0; i < numberOfGlyphs; i++) {
mtxTab[i].setOffset(locaFormat == 1 ? in.readTTFULong()
@@ -951,7 +952,9 @@ public class TTFFile {
*/
private final void readGlyf(FontFileReader in) throws IOException {
TTFDirTabEntry dirTab = (TTFDirTabEntry)dirTabs.get("glyf");
- if(dirTab==null) throw new IOException("glyf table not found, cannot continue");
+ if (dirTab == null) {
+ throw new IOException("glyf table not found, cannot continue");
+ }
for (int i = 0; i < (numberOfGlyphs - 1); i++) {
if (mtxTab[i].getOffset() != mtxTab[i + 1].getOffset()) {
in.seekSet(dirTab.getOffset() + mtxTab[i].getOffset());
diff --git a/src/java/org/apache/fop/pdf/PDFToUnicodeCMap.java b/src/java/org/apache/fop/pdf/PDFToUnicodeCMap.java
index 88264cf08..7f599a7a2 100644
--- a/src/java/org/apache/fop/pdf/PDFToUnicodeCMap.java
+++ b/src/java/org/apache/fop/pdf/PDFToUnicodeCMap.java
@@ -1,55 +1,26 @@
/*
- * $Id: PDFToUnicodeCMap.java,v 1.3.2.1 2005/12/01 12:00:00 ono Exp $
- * ============================================================================
- * The Apache Software License, Version 1.1
- * ============================================================================
- *
- * Copyright (C) 1999-2003 The Apache Software Foundation. All rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without modifica-
- * tion, are permitted provided that the following conditions are met:
- *
- * 1. Redistributions of source code must retain the above copyright notice,
- * this list of conditions and the following disclaimer.
- *
- * 2. Redistributions in binary form must reproduce the above copyright notice,
- * this list of conditions and the following disclaimer in the documentation
- * and/or other materials provided with the distribution.
- *
- * 3. The end-user documentation included with the redistribution, if any, must
- * include the following acknowledgment: "This product includes software
- * developed by the Apache Software Foundation (http://www.apache.org/)."
- * Alternately, this acknowledgment may appear in the software itself, if
- * and wherever such third-party acknowledgments normally appear.
- *
- * 4. The names "FOP" and "Apache Software Foundation" must not be used to
- * endorse or promote products derived from this software without prior
- * written permission. For written permission, please contact
- * apache@apache.org.
- *
- * 5. Products derived from this software may not be called "Apache", nor may
- * "Apache" appear in their name, without prior written permission of the
- * Apache Software Foundation.
- *
- * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,
- * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
- * FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
- * APACHE SOFTWARE FOUNDATION OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
- * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLU-
- * DING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
- * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
- * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
- * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- * ============================================================================
- *
- * This software consists of voluntary contributions made by many individuals
- * on behalf of the Apache Software Foundation and was originally created by
- * James Tauber <jtauber@jtauber.com>. For more information on the Apache
- * Software Foundation, please see <http://www.apache.org/>.
+ * 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.
*/
+
+/* $Id$ */
+
package org.apache.fop.pdf;
+import org.apache.fop.fonts.CIDFont;
+
/**
* Class representing ToUnicode CMaps.
* Here are some documentation resources:
@@ -63,8 +34,6 @@ package org.apache.fop.pdf;
* Adobe Technical Note #5411, "ToUnicode Mapping File Tutorial"</a>.
* </ul>
*/
-import org.apache.fop.fonts.CIDFont;
-
public class PDFToUnicodeCMap extends PDFCMap {
/**
@@ -75,6 +44,7 @@ public class PDFToUnicodeCMap extends PDFCMap {
/**
* Constructor.
*
+ * @param cidMetrics the CID font for which this Unicode CMap is built
* @param name One of the registered names found in Table 5.14 in PDF
* Reference, Second Edition.
* @param sysInfo The attributes of the character collection of the CIDFont.
@@ -84,6 +54,7 @@ public class PDFToUnicodeCMap extends PDFCMap {
cidFont = cidMetrics;
}
+ /** @see org.apache.fop.pdf.PDFCMap#fillInPDF(java.lang.StringBuffer) */
public void fillInPDF(StringBuffer p) {
writeCIDInit(p);
writeCIDSystemInfo(p);
@@ -94,6 +65,7 @@ public class PDFToUnicodeCMap extends PDFCMap {
add(p.toString());
}
+ /** @see org.apache.fop.pdf.PDFCMap#writeCIDSystemInfo(java.lang.StringBuffer) */
protected void writeCIDSystemInfo(StringBuffer p) {
p.append("/CIDSystemInfo\n");
p.append("<< /Registry (Adobe)\n");
@@ -102,6 +74,7 @@ public class PDFToUnicodeCMap extends PDFCMap {
p.append(">> def\n");
}
+ /** @see org.apache.fop.pdf.PDFCMap#writeVersionTypeName(java.lang.StringBuffer) */
protected void writeVersionTypeName(StringBuffer p) {
p.append("/CMapName /Adobe-Identity-UCS def\n");
p.append("/CMapType 2 def\n");
@@ -109,24 +82,33 @@ public class PDFToUnicodeCMap extends PDFCMap {
/**
* Writes the character mappings for this font.
+ * @param p StingBuffer to write to
*/
protected void writeBFEntries(StringBuffer p) {
- if(cidFont == null) return;
+ if (cidFont == null) {
+ return;
+ }
char[] charArray = cidFont.getCharsUsed();
- if(charArray != null) {
+ if (charArray != null) {
writeBFCharEntries(p, charArray);
writeBFRangeEntries(p, charArray);
}
}
+ /**
+ * Writes the entries for single characters of a base font (only characters which cannot be
+ * expressed as part of a character range).
+ * @param p StringBuffer to write to
+ * @param charArray all the characters to map
+ */
protected void writeBFCharEntries(StringBuffer p, char[] charArray) {
int completedEntries = 0;
int totalEntries = 0;
for (int i = 0; i < charArray.length; i++) {
- if (! partOfRange(charArray, i)) {
- totalEntries ++;
+ if (!partOfRange(charArray, i)) {
+ totalEntries++;
}
}
if (totalEntries < 1) {
@@ -146,9 +128,9 @@ public class PDFToUnicodeCMap extends PDFCMap {
p.append("<" + padHexString(Integer.toHexString(charArray[i]), 4)
+ ">\n");
/* Compute the statistics. */
- completedEntries ++;
+ completedEntries++;
remainingEntries = totalEntries - completedEntries;
- remainingEntriesThisSection --;
+ remainingEntriesThisSection--;
if (remainingEntriesThisSection < 1) {
if (remainingEntries > 0) {
p.append("endbfchar\n");
@@ -161,12 +143,17 @@ public class PDFToUnicodeCMap extends PDFCMap {
p.append("endbfchar\n");
}
+ /**
+ * Writes the entries for character ranges for a base font.
+ * @param p StringBuffer to write to
+ * @param charArray all the characters to map
+ */
protected void writeBFRangeEntries(StringBuffer p, char[] charArray) {
int completedEntries = 0;
int totalEntries = 0;
for (int i = 0; i < charArray.length; i++) {
if (startOfRange(charArray, i)) {
- totalEntries ++;
+ totalEntries++;
}
}
if (totalEntries < 1) {
@@ -177,7 +164,7 @@ public class PDFToUnicodeCMap extends PDFCMap {
int remainingEntriesThisSection = entriesThisSection;
p.append(entriesThisSection + " beginbfrange\n");
for (int i = 0; i < charArray.length; i++) {
- if (! startOfRange(charArray, i)) {
+ if (!startOfRange(charArray, i)) {
continue;
}
p.append("<"
@@ -191,7 +178,7 @@ public class PDFToUnicodeCMap extends PDFCMap {
+ padHexString(Integer.toHexString(charArray[i]), 4)
+ ">\n");
/* Compute the statistics. */
- completedEntries ++;
+ completedEntries++;
remainingEntries = totalEntries - completedEntries;
if (remainingEntriesThisSection < 1) {
if (remainingEntries > 0) {
@@ -216,7 +203,7 @@ public class PDFToUnicodeCMap extends PDFCMap {
int endOfRange = -1;
for (int i = startOfRange; i < charArray.length - 1 && endOfRange < 0;
i++) {
- if (! sameRangeEntryAsNext(charArray, i)) {
+ if (!sameRangeEntryAsNext(charArray, i)) {
endOfRange = i;
}
}
@@ -277,7 +264,7 @@ public class PDFToUnicodeCMap extends PDFCMap {
*/
private boolean startOfRange(char[] charArray, int arrayIndex) {
// Can't be the start of a range if not part of a range.
- if (! partOfRange(charArray, arrayIndex)) {
+ if (!partOfRange(charArray, arrayIndex)) {
return false;
}
// If first element in the array, must be start of a range