jaxp/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/XSLTC.java
author chegar
Sun, 17 Aug 2014 15:51:56 +0100
changeset 25868 686eef1e7a79
parent 21467 jaxp/src/com/sun/org/apache/xalan/internal/xsltc/compiler/XSLTC.java@ed77f0ff062c
child 29945 4912169d22d3
permissions -rw-r--r--
8054834: Modular Source Code Reviewed-by: alanb, chegar, ihse, mduigou Contributed-by: alan.bateman@oracle.com, alex.buckley@oracle.com, chris.hegarty@oracle.com, erik.joelsson@oracle.com, jonathan.gibbons@oracle.com, karen.kinnear@oracle.com, magnus.ihse.bursie@oracle.com, mandy.chung@oracle.com, mark.reinhold@oracle.com, paul.sandoz@oracle.com
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
6
7f561c08de6b Initial load
duke
parents:
diff changeset
     1
/*
7f561c08de6b Initial load
duke
parents:
diff changeset
     2
 * reserved comment block
7f561c08de6b Initial load
duke
parents:
diff changeset
     3
 * DO NOT REMOVE OR ALTER!
7f561c08de6b Initial load
duke
parents:
diff changeset
     4
 */
7f561c08de6b Initial load
duke
parents:
diff changeset
     5
/*
7f561c08de6b Initial load
duke
parents:
diff changeset
     6
 * Copyright 2001-2004 The Apache Software Foundation.
7f561c08de6b Initial load
duke
parents:
diff changeset
     7
 *
7f561c08de6b Initial load
duke
parents:
diff changeset
     8
 * Licensed under the Apache License, Version 2.0 (the "License");
7f561c08de6b Initial load
duke
parents:
diff changeset
     9
 * you may not use this file except in compliance with the License.
7f561c08de6b Initial load
duke
parents:
diff changeset
    10
 * You may obtain a copy of the License at
7f561c08de6b Initial load
duke
parents:
diff changeset
    11
 *
7f561c08de6b Initial load
duke
parents:
diff changeset
    12
 *     http://www.apache.org/licenses/LICENSE-2.0
7f561c08de6b Initial load
duke
parents:
diff changeset
    13
 *
7f561c08de6b Initial load
duke
parents:
diff changeset
    14
 * Unless required by applicable law or agreed to in writing, software
7f561c08de6b Initial load
duke
parents:
diff changeset
    15
 * distributed under the License is distributed on an "AS IS" BASIS,
7f561c08de6b Initial load
duke
parents:
diff changeset
    16
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
7f561c08de6b Initial load
duke
parents:
diff changeset
    17
 * See the License for the specific language governing permissions and
7f561c08de6b Initial load
duke
parents:
diff changeset
    18
 * limitations under the License.
7f561c08de6b Initial load
duke
parents:
diff changeset
    19
 */
7f561c08de6b Initial load
duke
parents:
diff changeset
    20
/*
7f561c08de6b Initial load
duke
parents:
diff changeset
    21
 * $Id: XSLTC.java,v 1.2.4.1 2005/09/05 09:51:38 pvedula Exp $
7f561c08de6b Initial load
duke
parents:
diff changeset
    22
 */
7f561c08de6b Initial load
duke
parents:
diff changeset
    23
7f561c08de6b Initial load
duke
parents:
diff changeset
    24
package com.sun.org.apache.xalan.internal.xsltc.compiler;
7f561c08de6b Initial load
duke
parents:
diff changeset
    25
7f561c08de6b Initial load
duke
parents:
diff changeset
    26
import java.io.BufferedOutputStream;
7f561c08de6b Initial load
duke
parents:
diff changeset
    27
import java.io.ByteArrayOutputStream;
7f561c08de6b Initial load
duke
parents:
diff changeset
    28
import java.io.File;
7f561c08de6b Initial load
duke
parents:
diff changeset
    29
import java.io.FileOutputStream;
7f561c08de6b Initial load
duke
parents:
diff changeset
    30
import java.io.IOException;
7f561c08de6b Initial load
duke
parents:
diff changeset
    31
import java.io.InputStream;
7f561c08de6b Initial load
duke
parents:
diff changeset
    32
import java.net.URL;
7f561c08de6b Initial load
duke
parents:
diff changeset
    33
import java.util.Date;
7f561c08de6b Initial load
duke
parents:
diff changeset
    34
import java.util.Enumeration;
7f561c08de6b Initial load
duke
parents:
diff changeset
    35
import java.util.Hashtable;
7f561c08de6b Initial load
duke
parents:
diff changeset
    36
import java.util.Map;
7f561c08de6b Initial load
duke
parents:
diff changeset
    37
import java.util.Properties;
7f561c08de6b Initial load
duke
parents:
diff changeset
    38
import java.util.Vector;
7f561c08de6b Initial load
duke
parents:
diff changeset
    39
import java.util.jar.JarEntry;
7f561c08de6b Initial load
duke
parents:
diff changeset
    40
import java.util.jar.JarOutputStream;
7f561c08de6b Initial load
duke
parents:
diff changeset
    41
import java.util.jar.Manifest;
17534
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
    42
import javax.xml.XMLConstants;
6
7f561c08de6b Initial load
duke
parents:
diff changeset
    43
7f561c08de6b Initial load
duke
parents:
diff changeset
    44
import com.sun.org.apache.bcel.internal.classfile.JavaClass;
17534
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
    45
import com.sun.org.apache.xalan.internal.XalanConstants;
21467
ed77f0ff062c 8004476: XSLT Extension Functions Don't Work in WebStart
joehw
parents: 20968
diff changeset
    46
import com.sun.org.apache.xalan.internal.utils.FeatureManager;
ed77f0ff062c 8004476: XSLT Extension Functions Don't Work in WebStart
joehw
parents: 20968
diff changeset
    47
import com.sun.org.apache.xalan.internal.utils.FeatureManager.Feature;
16953
a44e04deb948 6657673: Issues with JAXP
joehw
parents: 12458
diff changeset
    48
import com.sun.org.apache.xalan.internal.utils.SecuritySupport;
20968
dde41f8b7b96 8014530: Better digital signature processing
joehw
parents: 17534
diff changeset
    49
import com.sun.org.apache.xalan.internal.utils.XMLSecurityManager;
6
7f561c08de6b Initial load
duke
parents:
diff changeset
    50
import com.sun.org.apache.xalan.internal.xsltc.compiler.util.ErrorMsg;
7f561c08de6b Initial load
duke
parents:
diff changeset
    51
import com.sun.org.apache.xalan.internal.xsltc.compiler.util.Util;
7f561c08de6b Initial load
duke
parents:
diff changeset
    52
import com.sun.org.apache.xml.internal.dtm.DTM;
7f561c08de6b Initial load
duke
parents:
diff changeset
    53
7f561c08de6b Initial load
duke
parents:
diff changeset
    54
import org.xml.sax.InputSource;
7f561c08de6b Initial load
duke
parents:
diff changeset
    55
import org.xml.sax.XMLReader;
7f561c08de6b Initial load
duke
parents:
diff changeset
    56
7f561c08de6b Initial load
duke
parents:
diff changeset
    57
/**
7f561c08de6b Initial load
duke
parents:
diff changeset
    58
 * @author Jacek Ambroziak
7f561c08de6b Initial load
duke
parents:
diff changeset
    59
 * @author Santiago Pericas-Geertsen
7f561c08de6b Initial load
duke
parents:
diff changeset
    60
 * @author G. Todd Miller
7f561c08de6b Initial load
duke
parents:
diff changeset
    61
 * @author Morten Jorgensen
7f561c08de6b Initial load
duke
parents:
diff changeset
    62
 * @author John Howard (johnh@schemasoft.com)
7f561c08de6b Initial load
duke
parents:
diff changeset
    63
 */
7f561c08de6b Initial load
duke
parents:
diff changeset
    64
public final class XSLTC {
7f561c08de6b Initial load
duke
parents:
diff changeset
    65
7f561c08de6b Initial load
duke
parents:
diff changeset
    66
    // A reference to the main stylesheet parser object.
7f561c08de6b Initial load
duke
parents:
diff changeset
    67
    private Parser _parser;
7f561c08de6b Initial load
duke
parents:
diff changeset
    68
7f561c08de6b Initial load
duke
parents:
diff changeset
    69
    // A reference to an external XMLReader (SAX parser) passed to us
7f561c08de6b Initial load
duke
parents:
diff changeset
    70
    private XMLReader _reader = null;
7f561c08de6b Initial load
duke
parents:
diff changeset
    71
7f561c08de6b Initial load
duke
parents:
diff changeset
    72
    // A reference to an external SourceLoader (for use with include/import)
7f561c08de6b Initial load
duke
parents:
diff changeset
    73
    private SourceLoader _loader = null;
7f561c08de6b Initial load
duke
parents:
diff changeset
    74
7f561c08de6b Initial load
duke
parents:
diff changeset
    75
    // A reference to the stylesheet being compiled.
7f561c08de6b Initial load
duke
parents:
diff changeset
    76
    private Stylesheet _stylesheet;
7f561c08de6b Initial load
duke
parents:
diff changeset
    77
7f561c08de6b Initial load
duke
parents:
diff changeset
    78
    // Counters used by various classes to generate unique names.
7f561c08de6b Initial load
duke
parents:
diff changeset
    79
    // private int _variableSerial     = 1;
7f561c08de6b Initial load
duke
parents:
diff changeset
    80
    private int _modeSerial         = 1;
7f561c08de6b Initial load
duke
parents:
diff changeset
    81
    private int _stylesheetSerial   = 1;
7f561c08de6b Initial load
duke
parents:
diff changeset
    82
    private int _stepPatternSerial  = 1;
7f561c08de6b Initial load
duke
parents:
diff changeset
    83
    private int _helperClassSerial  = 0;
7f561c08de6b Initial load
duke
parents:
diff changeset
    84
    private int _attributeSetSerial = 0;
7f561c08de6b Initial load
duke
parents:
diff changeset
    85
7f561c08de6b Initial load
duke
parents:
diff changeset
    86
    private int[] _numberFieldIndexes;
7f561c08de6b Initial load
duke
parents:
diff changeset
    87
7f561c08de6b Initial load
duke
parents:
diff changeset
    88
    // Name index tables
7f561c08de6b Initial load
duke
parents:
diff changeset
    89
    private int       _nextGType;  // Next available element type
7f561c08de6b Initial load
duke
parents:
diff changeset
    90
    private Vector    _namesIndex; // Index of all registered QNames
7f561c08de6b Initial load
duke
parents:
diff changeset
    91
    private Hashtable _elements;   // Hashtable of all registered elements
7f561c08de6b Initial load
duke
parents:
diff changeset
    92
    private Hashtable _attributes; // Hashtable of all registered attributes
7f561c08de6b Initial load
duke
parents:
diff changeset
    93
7f561c08de6b Initial load
duke
parents:
diff changeset
    94
    // Namespace index tables
7f561c08de6b Initial load
duke
parents:
diff changeset
    95
    private int       _nextNSType; // Next available namespace type
7f561c08de6b Initial load
duke
parents:
diff changeset
    96
    private Vector    _namespaceIndex; // Index of all registered namespaces
7f561c08de6b Initial load
duke
parents:
diff changeset
    97
    private Hashtable _namespaces; // Hashtable of all registered namespaces
7f561c08de6b Initial load
duke
parents:
diff changeset
    98
    private Hashtable _namespacePrefixes;// Hashtable of all registered namespace prefixes
7f561c08de6b Initial load
duke
parents:
diff changeset
    99
7f561c08de6b Initial load
duke
parents:
diff changeset
   100
7f561c08de6b Initial load
duke
parents:
diff changeset
   101
    // All literal text in the stylesheet
7f561c08de6b Initial load
duke
parents:
diff changeset
   102
    private Vector m_characterData;
7f561c08de6b Initial load
duke
parents:
diff changeset
   103
7f561c08de6b Initial load
duke
parents:
diff changeset
   104
    // These define the various methods for outputting the translet
7f561c08de6b Initial load
duke
parents:
diff changeset
   105
    public static final int FILE_OUTPUT        = 0;
7f561c08de6b Initial load
duke
parents:
diff changeset
   106
    public static final int JAR_OUTPUT         = 1;
7f561c08de6b Initial load
duke
parents:
diff changeset
   107
    public static final int BYTEARRAY_OUTPUT   = 2;
7f561c08de6b Initial load
duke
parents:
diff changeset
   108
    public static final int CLASSLOADER_OUTPUT = 3;
7f561c08de6b Initial load
duke
parents:
diff changeset
   109
    public static final int BYTEARRAY_AND_FILE_OUTPUT = 4;
7f561c08de6b Initial load
duke
parents:
diff changeset
   110
    public static final int BYTEARRAY_AND_JAR_OUTPUT  = 5;
7f561c08de6b Initial load
duke
parents:
diff changeset
   111
7f561c08de6b Initial load
duke
parents:
diff changeset
   112
7f561c08de6b Initial load
duke
parents:
diff changeset
   113
    // Compiler options (passed from command line or XSLTC client)
7f561c08de6b Initial load
duke
parents:
diff changeset
   114
    private boolean _debug = false;      // -x
7f561c08de6b Initial load
duke
parents:
diff changeset
   115
    private String  _jarFileName = null; // -j <jar-file-name>
7f561c08de6b Initial load
duke
parents:
diff changeset
   116
    private String  _className = null;   // -o <class-name>
7f561c08de6b Initial load
duke
parents:
diff changeset
   117
    private String  _packageName = null; // -p <package-name>
7f561c08de6b Initial load
duke
parents:
diff changeset
   118
    private File    _destDir = null;     // -d <directory-name>
7f561c08de6b Initial load
duke
parents:
diff changeset
   119
    private int     _outputType = FILE_OUTPUT; // by default
7f561c08de6b Initial load
duke
parents:
diff changeset
   120
7f561c08de6b Initial load
duke
parents:
diff changeset
   121
    private Vector  _classes;
7f561c08de6b Initial load
duke
parents:
diff changeset
   122
    private Vector  _bcelClasses;
7f561c08de6b Initial load
duke
parents:
diff changeset
   123
    private boolean _callsNodeset = false;
7f561c08de6b Initial load
duke
parents:
diff changeset
   124
    private boolean _multiDocument = false;
7f561c08de6b Initial load
duke
parents:
diff changeset
   125
    private boolean _hasIdCall = false;
7f561c08de6b Initial load
duke
parents:
diff changeset
   126
7f561c08de6b Initial load
duke
parents:
diff changeset
   127
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   128
     * Set to true if template inlining is requested. Template
7f561c08de6b Initial load
duke
parents:
diff changeset
   129
     * inlining used to be the default, but we have found that
7f561c08de6b Initial load
duke
parents:
diff changeset
   130
     * Hotspots does a better job with shorter methods, so the
7f561c08de6b Initial load
duke
parents:
diff changeset
   131
     * default is *not* to inline now.
7f561c08de6b Initial load
duke
parents:
diff changeset
   132
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   133
    private boolean _templateInlining = false;
7f561c08de6b Initial load
duke
parents:
diff changeset
   134
7f561c08de6b Initial load
duke
parents:
diff changeset
   135
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   136
     * State of the secure processing feature.
7f561c08de6b Initial load
duke
parents:
diff changeset
   137
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   138
    private boolean _isSecureProcessing = false;
7f561c08de6b Initial load
duke
parents:
diff changeset
   139
12458
d601e4bba306 7160380: Sync JDK8 with JAXP 1.4.5
joehw
parents: 12457
diff changeset
   140
    private boolean _useServicesMechanism = true;
d601e4bba306 7160380: Sync JDK8 with JAXP 1.4.5
joehw
parents: 12457
diff changeset
   141
6
7f561c08de6b Initial load
duke
parents:
diff changeset
   142
    /**
17534
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   143
     * protocols allowed for external references set by the stylesheet processing instruction, Import and Include element.
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   144
     */
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   145
    private String _accessExternalStylesheet = XalanConstants.EXTERNAL_ACCESS_DEFAULT;
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   146
     /**
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   147
     * protocols allowed for external DTD references in source file and/or stylesheet.
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   148
     */
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   149
    private String _accessExternalDTD = XalanConstants.EXTERNAL_ACCESS_DEFAULT;
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   150
20968
dde41f8b7b96 8014530: Better digital signature processing
joehw
parents: 17534
diff changeset
   151
    private XMLSecurityManager _xmlSecurityManager;
17534
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   152
21467
ed77f0ff062c 8004476: XSLT Extension Functions Don't Work in WebStart
joehw
parents: 20968
diff changeset
   153
    private final FeatureManager _featureManager;
ed77f0ff062c 8004476: XSLT Extension Functions Don't Work in WebStart
joehw
parents: 20968
diff changeset
   154
17534
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   155
    /**
6
7f561c08de6b Initial load
duke
parents:
diff changeset
   156
     * XSLTC compiler constructor
7f561c08de6b Initial load
duke
parents:
diff changeset
   157
     */
21467
ed77f0ff062c 8004476: XSLT Extension Functions Don't Work in WebStart
joehw
parents: 20968
diff changeset
   158
    public XSLTC(boolean useServicesMechanism, FeatureManager featureManager) {
12458
d601e4bba306 7160380: Sync JDK8 with JAXP 1.4.5
joehw
parents: 12457
diff changeset
   159
        _parser = new Parser(this, useServicesMechanism);
21467
ed77f0ff062c 8004476: XSLT Extension Functions Don't Work in WebStart
joehw
parents: 20968
diff changeset
   160
        _featureManager = featureManager;
6
7f561c08de6b Initial load
duke
parents:
diff changeset
   161
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   162
7f561c08de6b Initial load
duke
parents:
diff changeset
   163
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   164
     * Set the state of the secure processing feature.
7f561c08de6b Initial load
duke
parents:
diff changeset
   165
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   166
    public void setSecureProcessing(boolean flag) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   167
        _isSecureProcessing = flag;
7f561c08de6b Initial load
duke
parents:
diff changeset
   168
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   169
7f561c08de6b Initial load
duke
parents:
diff changeset
   170
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   171
     * Return the state of the secure processing feature.
7f561c08de6b Initial load
duke
parents:
diff changeset
   172
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   173
    public boolean isSecureProcessing() {
7f561c08de6b Initial load
duke
parents:
diff changeset
   174
        return _isSecureProcessing;
7f561c08de6b Initial load
duke
parents:
diff changeset
   175
    }
12458
d601e4bba306 7160380: Sync JDK8 with JAXP 1.4.5
joehw
parents: 12457
diff changeset
   176
    /**
d601e4bba306 7160380: Sync JDK8 with JAXP 1.4.5
joehw
parents: 12457
diff changeset
   177
     * Return the state of the services mechanism feature.
d601e4bba306 7160380: Sync JDK8 with JAXP 1.4.5
joehw
parents: 12457
diff changeset
   178
     */
d601e4bba306 7160380: Sync JDK8 with JAXP 1.4.5
joehw
parents: 12457
diff changeset
   179
    public boolean useServicesMechnism() {
d601e4bba306 7160380: Sync JDK8 with JAXP 1.4.5
joehw
parents: 12457
diff changeset
   180
        return _useServicesMechanism;
d601e4bba306 7160380: Sync JDK8 with JAXP 1.4.5
joehw
parents: 12457
diff changeset
   181
    }
d601e4bba306 7160380: Sync JDK8 with JAXP 1.4.5
joehw
parents: 12457
diff changeset
   182
d601e4bba306 7160380: Sync JDK8 with JAXP 1.4.5
joehw
parents: 12457
diff changeset
   183
    /**
d601e4bba306 7160380: Sync JDK8 with JAXP 1.4.5
joehw
parents: 12457
diff changeset
   184
     * Set the state of the services mechanism feature.
d601e4bba306 7160380: Sync JDK8 with JAXP 1.4.5
joehw
parents: 12457
diff changeset
   185
     */
d601e4bba306 7160380: Sync JDK8 with JAXP 1.4.5
joehw
parents: 12457
diff changeset
   186
    public void setServicesMechnism(boolean flag) {
d601e4bba306 7160380: Sync JDK8 with JAXP 1.4.5
joehw
parents: 12457
diff changeset
   187
        _useServicesMechanism = flag;
d601e4bba306 7160380: Sync JDK8 with JAXP 1.4.5
joehw
parents: 12457
diff changeset
   188
    }
6
7f561c08de6b Initial load
duke
parents:
diff changeset
   189
21467
ed77f0ff062c 8004476: XSLT Extension Functions Don't Work in WebStart
joehw
parents: 20968
diff changeset
   190
     /**
ed77f0ff062c 8004476: XSLT Extension Functions Don't Work in WebStart
joehw
parents: 20968
diff changeset
   191
     * Return the value of the specified feature
ed77f0ff062c 8004476: XSLT Extension Functions Don't Work in WebStart
joehw
parents: 20968
diff changeset
   192
     * @param name name of the feature
ed77f0ff062c 8004476: XSLT Extension Functions Don't Work in WebStart
joehw
parents: 20968
diff changeset
   193
     * @return true if the feature is enabled, false otherwise
ed77f0ff062c 8004476: XSLT Extension Functions Don't Work in WebStart
joehw
parents: 20968
diff changeset
   194
     */
ed77f0ff062c 8004476: XSLT Extension Functions Don't Work in WebStart
joehw
parents: 20968
diff changeset
   195
    public boolean getFeature(Feature name) {
ed77f0ff062c 8004476: XSLT Extension Functions Don't Work in WebStart
joehw
parents: 20968
diff changeset
   196
        return _featureManager.isFeatureEnabled(name);
ed77f0ff062c 8004476: XSLT Extension Functions Don't Work in WebStart
joehw
parents: 20968
diff changeset
   197
    }
ed77f0ff062c 8004476: XSLT Extension Functions Don't Work in WebStart
joehw
parents: 20968
diff changeset
   198
6
7f561c08de6b Initial load
duke
parents:
diff changeset
   199
    /**
17534
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   200
     * Return allowed protocols for accessing external stylesheet.
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   201
     */
20968
dde41f8b7b96 8014530: Better digital signature processing
joehw
parents: 17534
diff changeset
   202
    public Object getProperty(String name) {
17534
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   203
        if (name.equals(XMLConstants.ACCESS_EXTERNAL_STYLESHEET)) {
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   204
            return _accessExternalStylesheet;
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   205
        }
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   206
        else if (name.equals(XMLConstants.ACCESS_EXTERNAL_DTD)) {
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   207
            return _accessExternalDTD;
20968
dde41f8b7b96 8014530: Better digital signature processing
joehw
parents: 17534
diff changeset
   208
        } else if (name.equals(XalanConstants.SECURITY_MANAGER)) {
dde41f8b7b96 8014530: Better digital signature processing
joehw
parents: 17534
diff changeset
   209
            return _xmlSecurityManager;
17534
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   210
        }
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   211
        return null;
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   212
    }
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   213
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   214
    /**
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   215
     * Set allowed protocols for accessing external stylesheet.
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   216
     */
20968
dde41f8b7b96 8014530: Better digital signature processing
joehw
parents: 17534
diff changeset
   217
    public void setProperty(String name, Object value) {
17534
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   218
        if (name.equals(XMLConstants.ACCESS_EXTERNAL_STYLESHEET)) {
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   219
            _accessExternalStylesheet = (String)value;
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   220
        }
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   221
        else if (name.equals(XMLConstants.ACCESS_EXTERNAL_DTD)) {
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   222
            _accessExternalDTD = (String)value;
20968
dde41f8b7b96 8014530: Better digital signature processing
joehw
parents: 17534
diff changeset
   223
        } else if (name.equals(XalanConstants.SECURITY_MANAGER)) {
dde41f8b7b96 8014530: Better digital signature processing
joehw
parents: 17534
diff changeset
   224
            _xmlSecurityManager = (XMLSecurityManager)value;
17534
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   225
        }
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   226
    }
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   227
21dc0b2762da 8011653: Upgrade JDK8 to JAXP 1.5
joehw
parents: 16953
diff changeset
   228
    /**
6
7f561c08de6b Initial load
duke
parents:
diff changeset
   229
     * Only for user by the internal TrAX implementation.
7f561c08de6b Initial load
duke
parents:
diff changeset
   230
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   231
    public Parser getParser() {
7f561c08de6b Initial load
duke
parents:
diff changeset
   232
        return _parser;
7f561c08de6b Initial load
duke
parents:
diff changeset
   233
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   234
7f561c08de6b Initial load
duke
parents:
diff changeset
   235
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   236
     * Only for user by the internal TrAX implementation.
7f561c08de6b Initial load
duke
parents:
diff changeset
   237
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   238
    public void setOutputType(int type) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   239
        _outputType = type;
7f561c08de6b Initial load
duke
parents:
diff changeset
   240
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   241
7f561c08de6b Initial load
duke
parents:
diff changeset
   242
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   243
     * Only for user by the internal TrAX implementation.
7f561c08de6b Initial load
duke
parents:
diff changeset
   244
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   245
    public Properties getOutputProperties() {
7f561c08de6b Initial load
duke
parents:
diff changeset
   246
        return _parser.getOutputProperties();
7f561c08de6b Initial load
duke
parents:
diff changeset
   247
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   248
7f561c08de6b Initial load
duke
parents:
diff changeset
   249
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   250
     * Initializes the compiler to compile a new stylesheet
7f561c08de6b Initial load
duke
parents:
diff changeset
   251
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   252
    public void init() {
7f561c08de6b Initial load
duke
parents:
diff changeset
   253
        reset();
7f561c08de6b Initial load
duke
parents:
diff changeset
   254
        _reader = null;
7f561c08de6b Initial load
duke
parents:
diff changeset
   255
        _classes = new Vector();
7f561c08de6b Initial load
duke
parents:
diff changeset
   256
        _bcelClasses = new Vector();
7f561c08de6b Initial load
duke
parents:
diff changeset
   257
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   258
7f561c08de6b Initial load
duke
parents:
diff changeset
   259
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   260
     * Initializes the compiler to produce a new translet
7f561c08de6b Initial load
duke
parents:
diff changeset
   261
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   262
    private void reset() {
7f561c08de6b Initial load
duke
parents:
diff changeset
   263
        _nextGType      = DTM.NTYPES;
7f561c08de6b Initial load
duke
parents:
diff changeset
   264
        _elements       = new Hashtable();
7f561c08de6b Initial load
duke
parents:
diff changeset
   265
        _attributes     = new Hashtable();
7f561c08de6b Initial load
duke
parents:
diff changeset
   266
        _namespaces     = new Hashtable();
7f561c08de6b Initial load
duke
parents:
diff changeset
   267
        _namespaces.put("",new Integer(_nextNSType));
7f561c08de6b Initial load
duke
parents:
diff changeset
   268
        _namesIndex     = new Vector(128);
7f561c08de6b Initial load
duke
parents:
diff changeset
   269
        _namespaceIndex = new Vector(32);
7f561c08de6b Initial load
duke
parents:
diff changeset
   270
        _namespacePrefixes = new Hashtable();
7f561c08de6b Initial load
duke
parents:
diff changeset
   271
        _stylesheet     = null;
7f561c08de6b Initial load
duke
parents:
diff changeset
   272
        _parser.init();
7f561c08de6b Initial load
duke
parents:
diff changeset
   273
        //_variableSerial     = 1;
7f561c08de6b Initial load
duke
parents:
diff changeset
   274
        _modeSerial         = 1;
7f561c08de6b Initial load
duke
parents:
diff changeset
   275
        _stylesheetSerial   = 1;
7f561c08de6b Initial load
duke
parents:
diff changeset
   276
        _stepPatternSerial  = 1;
7f561c08de6b Initial load
duke
parents:
diff changeset
   277
        _helperClassSerial  = 0;
7f561c08de6b Initial load
duke
parents:
diff changeset
   278
        _attributeSetSerial = 0;
7f561c08de6b Initial load
duke
parents:
diff changeset
   279
        _multiDocument      = false;
7f561c08de6b Initial load
duke
parents:
diff changeset
   280
        _hasIdCall          = false;
7f561c08de6b Initial load
duke
parents:
diff changeset
   281
        _numberFieldIndexes = new int[] {
7f561c08de6b Initial load
duke
parents:
diff changeset
   282
            -1,         // LEVEL_SINGLE
7f561c08de6b Initial load
duke
parents:
diff changeset
   283
            -1,         // LEVEL_MULTIPLE
7f561c08de6b Initial load
duke
parents:
diff changeset
   284
            -1          // LEVEL_ANY
7f561c08de6b Initial load
duke
parents:
diff changeset
   285
        };
7f561c08de6b Initial load
duke
parents:
diff changeset
   286
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   287
7f561c08de6b Initial load
duke
parents:
diff changeset
   288
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   289
     * Defines an external SourceLoader to provide the compiler with documents
7f561c08de6b Initial load
duke
parents:
diff changeset
   290
     * referenced in xsl:include/import
7f561c08de6b Initial load
duke
parents:
diff changeset
   291
     * @param loader The SourceLoader to use for include/import
7f561c08de6b Initial load
duke
parents:
diff changeset
   292
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   293
    public void setSourceLoader(SourceLoader loader) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   294
        _loader = loader;
7f561c08de6b Initial load
duke
parents:
diff changeset
   295
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   296
7f561c08de6b Initial load
duke
parents:
diff changeset
   297
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   298
     * Set a flag indicating if templates are to be inlined or not. The
7f561c08de6b Initial load
duke
parents:
diff changeset
   299
     * default is to do inlining, but this causes problems when the
7f561c08de6b Initial load
duke
parents:
diff changeset
   300
     * stylesheets have a large number of templates (e.g. branch targets
7f561c08de6b Initial load
duke
parents:
diff changeset
   301
     * exceeding 64K or a length of a method exceeding 64K).
7f561c08de6b Initial load
duke
parents:
diff changeset
   302
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   303
    public void setTemplateInlining(boolean templateInlining) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   304
        _templateInlining = templateInlining;
7f561c08de6b Initial load
duke
parents:
diff changeset
   305
    }
12458
d601e4bba306 7160380: Sync JDK8 with JAXP 1.4.5
joehw
parents: 12457
diff changeset
   306
     /**
d601e4bba306 7160380: Sync JDK8 with JAXP 1.4.5
joehw
parents: 12457
diff changeset
   307
     * Return the state of the template inlining feature.
d601e4bba306 7160380: Sync JDK8 with JAXP 1.4.5
joehw
parents: 12457
diff changeset
   308
     */
d601e4bba306 7160380: Sync JDK8 with JAXP 1.4.5
joehw
parents: 12457
diff changeset
   309
    public boolean getTemplateInlining() {
d601e4bba306 7160380: Sync JDK8 with JAXP 1.4.5
joehw
parents: 12457
diff changeset
   310
        return _templateInlining;
d601e4bba306 7160380: Sync JDK8 with JAXP 1.4.5
joehw
parents: 12457
diff changeset
   311
    }
6
7f561c08de6b Initial load
duke
parents:
diff changeset
   312
7f561c08de6b Initial load
duke
parents:
diff changeset
   313
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   314
     * Set the parameters to use to locate the correct <?xml-stylesheet ...?>
7f561c08de6b Initial load
duke
parents:
diff changeset
   315
     * processing instruction in the case where the input document to the
7f561c08de6b Initial load
duke
parents:
diff changeset
   316
     * compiler (and parser) is an XML document.
7f561c08de6b Initial load
duke
parents:
diff changeset
   317
     * @param media The media attribute to be matched. May be null, in which
7f561c08de6b Initial load
duke
parents:
diff changeset
   318
     * case the prefered templates will be used (i.e. alternate = no).
7f561c08de6b Initial load
duke
parents:
diff changeset
   319
     * @param title The value of the title attribute to match. May be null.
7f561c08de6b Initial load
duke
parents:
diff changeset
   320
     * @param charset The value of the charset attribute to match. May be null.
7f561c08de6b Initial load
duke
parents:
diff changeset
   321
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   322
    public void setPIParameters(String media, String title, String charset) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   323
        _parser.setPIParameters(media, title, charset);
7f561c08de6b Initial load
duke
parents:
diff changeset
   324
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   325
7f561c08de6b Initial load
duke
parents:
diff changeset
   326
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   327
     * Compiles an XSL stylesheet pointed to by a URL
7f561c08de6b Initial load
duke
parents:
diff changeset
   328
     * @param url An URL containing the input XSL stylesheet
7f561c08de6b Initial load
duke
parents:
diff changeset
   329
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   330
    public boolean compile(URL url) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   331
        try {
7f561c08de6b Initial load
duke
parents:
diff changeset
   332
            // Open input stream from URL and wrap inside InputSource
7f561c08de6b Initial load
duke
parents:
diff changeset
   333
            final InputStream stream = url.openStream();
7f561c08de6b Initial load
duke
parents:
diff changeset
   334
            final InputSource input = new InputSource(stream);
7f561c08de6b Initial load
duke
parents:
diff changeset
   335
            input.setSystemId(url.toString());
7f561c08de6b Initial load
duke
parents:
diff changeset
   336
            return compile(input, _className);
7f561c08de6b Initial load
duke
parents:
diff changeset
   337
        }
7f561c08de6b Initial load
duke
parents:
diff changeset
   338
        catch (IOException e) {
16953
a44e04deb948 6657673: Issues with JAXP
joehw
parents: 12458
diff changeset
   339
            _parser.reportError(Constants.FATAL, new ErrorMsg(ErrorMsg.JAXP_COMPILE_ERR, e));
6
7f561c08de6b Initial load
duke
parents:
diff changeset
   340
            return false;
7f561c08de6b Initial load
duke
parents:
diff changeset
   341
        }
7f561c08de6b Initial load
duke
parents:
diff changeset
   342
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   343
7f561c08de6b Initial load
duke
parents:
diff changeset
   344
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   345
     * Compiles an XSL stylesheet pointed to by a URL
7f561c08de6b Initial load
duke
parents:
diff changeset
   346
     * @param url An URL containing the input XSL stylesheet
7f561c08de6b Initial load
duke
parents:
diff changeset
   347
     * @param name The name to assign to the translet class
7f561c08de6b Initial load
duke
parents:
diff changeset
   348
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   349
    public boolean compile(URL url, String name) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   350
        try {
7f561c08de6b Initial load
duke
parents:
diff changeset
   351
            // Open input stream from URL and wrap inside InputSource
7f561c08de6b Initial load
duke
parents:
diff changeset
   352
            final InputStream stream = url.openStream();
7f561c08de6b Initial load
duke
parents:
diff changeset
   353
            final InputSource input = new InputSource(stream);
7f561c08de6b Initial load
duke
parents:
diff changeset
   354
            input.setSystemId(url.toString());
7f561c08de6b Initial load
duke
parents:
diff changeset
   355
            return compile(input, name);
7f561c08de6b Initial load
duke
parents:
diff changeset
   356
        }
7f561c08de6b Initial load
duke
parents:
diff changeset
   357
        catch (IOException e) {
16953
a44e04deb948 6657673: Issues with JAXP
joehw
parents: 12458
diff changeset
   358
            _parser.reportError(Constants.FATAL, new ErrorMsg(ErrorMsg.JAXP_COMPILE_ERR, e));
6
7f561c08de6b Initial load
duke
parents:
diff changeset
   359
            return false;
7f561c08de6b Initial load
duke
parents:
diff changeset
   360
        }
7f561c08de6b Initial load
duke
parents:
diff changeset
   361
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   362
7f561c08de6b Initial load
duke
parents:
diff changeset
   363
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   364
     * Compiles an XSL stylesheet passed in through an InputStream
7f561c08de6b Initial load
duke
parents:
diff changeset
   365
     * @param stream An InputStream that will pass in the stylesheet contents
7f561c08de6b Initial load
duke
parents:
diff changeset
   366
     * @param name The name of the translet class to generate
7f561c08de6b Initial load
duke
parents:
diff changeset
   367
     * @return 'true' if the compilation was successful
7f561c08de6b Initial load
duke
parents:
diff changeset
   368
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   369
    public boolean compile(InputStream stream, String name) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   370
        final InputSource input = new InputSource(stream);
7f561c08de6b Initial load
duke
parents:
diff changeset
   371
        input.setSystemId(name); // We have nothing else!!!
7f561c08de6b Initial load
duke
parents:
diff changeset
   372
        return compile(input, name);
7f561c08de6b Initial load
duke
parents:
diff changeset
   373
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   374
7f561c08de6b Initial load
duke
parents:
diff changeset
   375
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   376
     * Compiles an XSL stylesheet passed in through an InputStream
7f561c08de6b Initial load
duke
parents:
diff changeset
   377
     * @param input An InputSource that will pass in the stylesheet contents
7f561c08de6b Initial load
duke
parents:
diff changeset
   378
     * @param name The name of the translet class to generate - can be null
7f561c08de6b Initial load
duke
parents:
diff changeset
   379
     * @return 'true' if the compilation was successful
7f561c08de6b Initial load
duke
parents:
diff changeset
   380
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   381
    public boolean compile(InputSource input, String name) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   382
        try {
7f561c08de6b Initial load
duke
parents:
diff changeset
   383
            // Reset globals in case we're called by compile(Vector v);
7f561c08de6b Initial load
duke
parents:
diff changeset
   384
            reset();
7f561c08de6b Initial load
duke
parents:
diff changeset
   385
7f561c08de6b Initial load
duke
parents:
diff changeset
   386
            // The systemId may not be set, so we'll have to check the URL
7f561c08de6b Initial load
duke
parents:
diff changeset
   387
            String systemId = null;
7f561c08de6b Initial load
duke
parents:
diff changeset
   388
            if (input != null) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   389
                systemId = input.getSystemId();
7f561c08de6b Initial load
duke
parents:
diff changeset
   390
            }
7f561c08de6b Initial load
duke
parents:
diff changeset
   391
7f561c08de6b Initial load
duke
parents:
diff changeset
   392
            // Set the translet class name if not already set
7f561c08de6b Initial load
duke
parents:
diff changeset
   393
            if (_className == null) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   394
                if (name != null) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   395
                    setClassName(name);
7f561c08de6b Initial load
duke
parents:
diff changeset
   396
                }
7f561c08de6b Initial load
duke
parents:
diff changeset
   397
                else if (systemId != null && !systemId.equals("")) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   398
                    setClassName(Util.baseName(systemId));
7f561c08de6b Initial load
duke
parents:
diff changeset
   399
                }
7f561c08de6b Initial load
duke
parents:
diff changeset
   400
7f561c08de6b Initial load
duke
parents:
diff changeset
   401
                // Ensure we have a non-empty class name at this point
7f561c08de6b Initial load
duke
parents:
diff changeset
   402
                if (_className == null || _className.length() == 0) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   403
                    setClassName("GregorSamsa"); // default translet name
7f561c08de6b Initial load
duke
parents:
diff changeset
   404
                }
7f561c08de6b Initial load
duke
parents:
diff changeset
   405
            }
7f561c08de6b Initial load
duke
parents:
diff changeset
   406
7f561c08de6b Initial load
duke
parents:
diff changeset
   407
            // Get the root node of the abstract syntax tree
7f561c08de6b Initial load
duke
parents:
diff changeset
   408
            SyntaxTreeNode element = null;
7f561c08de6b Initial load
duke
parents:
diff changeset
   409
            if (_reader == null) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   410
                element = _parser.parse(input);
7f561c08de6b Initial load
duke
parents:
diff changeset
   411
            }
7f561c08de6b Initial load
duke
parents:
diff changeset
   412
            else {
7f561c08de6b Initial load
duke
parents:
diff changeset
   413
                element = _parser.parse(_reader, input);
7f561c08de6b Initial load
duke
parents:
diff changeset
   414
            }
7f561c08de6b Initial load
duke
parents:
diff changeset
   415
7f561c08de6b Initial load
duke
parents:
diff changeset
   416
            // Compile the translet - this is where the work is done!
7f561c08de6b Initial load
duke
parents:
diff changeset
   417
            if ((!_parser.errorsFound()) && (element != null)) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   418
                // Create a Stylesheet element from the root node
7f561c08de6b Initial load
duke
parents:
diff changeset
   419
                _stylesheet = _parser.makeStylesheet(element);
7f561c08de6b Initial load
duke
parents:
diff changeset
   420
                _stylesheet.setSourceLoader(_loader);
7f561c08de6b Initial load
duke
parents:
diff changeset
   421
                _stylesheet.setSystemId(systemId);
7f561c08de6b Initial load
duke
parents:
diff changeset
   422
                _stylesheet.setParentStylesheet(null);
7f561c08de6b Initial load
duke
parents:
diff changeset
   423
                _stylesheet.setTemplateInlining(_templateInlining);
7f561c08de6b Initial load
duke
parents:
diff changeset
   424
                _parser.setCurrentStylesheet(_stylesheet);
7f561c08de6b Initial load
duke
parents:
diff changeset
   425
7f561c08de6b Initial load
duke
parents:
diff changeset
   426
                // Create AST under the Stylesheet element (parse & type-check)
7f561c08de6b Initial load
duke
parents:
diff changeset
   427
                _parser.createAST(_stylesheet);
7f561c08de6b Initial load
duke
parents:
diff changeset
   428
            }
7f561c08de6b Initial load
duke
parents:
diff changeset
   429
            // Generate the bytecodes and output the translet class(es)
7f561c08de6b Initial load
duke
parents:
diff changeset
   430
            if ((!_parser.errorsFound()) && (_stylesheet != null)) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   431
                _stylesheet.setCallsNodeset(_callsNodeset);
7f561c08de6b Initial load
duke
parents:
diff changeset
   432
                _stylesheet.setMultiDocument(_multiDocument);
7f561c08de6b Initial load
duke
parents:
diff changeset
   433
                _stylesheet.setHasIdCall(_hasIdCall);
7f561c08de6b Initial load
duke
parents:
diff changeset
   434
7f561c08de6b Initial load
duke
parents:
diff changeset
   435
                // Class synchronization is needed for BCEL
7f561c08de6b Initial load
duke
parents:
diff changeset
   436
                synchronized (getClass()) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   437
                    _stylesheet.translate();
7f561c08de6b Initial load
duke
parents:
diff changeset
   438
                }
7f561c08de6b Initial load
duke
parents:
diff changeset
   439
            }
7f561c08de6b Initial load
duke
parents:
diff changeset
   440
        }
7f561c08de6b Initial load
duke
parents:
diff changeset
   441
        catch (Exception e) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   442
            /*if (_debug)*/ e.printStackTrace();
16953
a44e04deb948 6657673: Issues with JAXP
joehw
parents: 12458
diff changeset
   443
            _parser.reportError(Constants.FATAL, new ErrorMsg(ErrorMsg.JAXP_COMPILE_ERR, e));
6
7f561c08de6b Initial load
duke
parents:
diff changeset
   444
        }
7f561c08de6b Initial load
duke
parents:
diff changeset
   445
        catch (Error e) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   446
            if (_debug) e.printStackTrace();
16953
a44e04deb948 6657673: Issues with JAXP
joehw
parents: 12458
diff changeset
   447
            _parser.reportError(Constants.FATAL, new ErrorMsg(ErrorMsg.JAXP_COMPILE_ERR, e));
6
7f561c08de6b Initial load
duke
parents:
diff changeset
   448
        }
7f561c08de6b Initial load
duke
parents:
diff changeset
   449
        finally {
7f561c08de6b Initial load
duke
parents:
diff changeset
   450
            _reader = null; // reset this here to be sure it is not re-used
7f561c08de6b Initial load
duke
parents:
diff changeset
   451
        }
7f561c08de6b Initial load
duke
parents:
diff changeset
   452
        return !_parser.errorsFound();
7f561c08de6b Initial load
duke
parents:
diff changeset
   453
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   454
7f561c08de6b Initial load
duke
parents:
diff changeset
   455
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   456
     * Compiles a set of stylesheets pointed to by a Vector of URLs
7f561c08de6b Initial load
duke
parents:
diff changeset
   457
     * @param stylesheets A Vector containing URLs pointing to the stylesheets
7f561c08de6b Initial load
duke
parents:
diff changeset
   458
     * @return 'true' if the compilation was successful
7f561c08de6b Initial load
duke
parents:
diff changeset
   459
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   460
    public boolean compile(Vector stylesheets) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   461
        // Get the number of stylesheets (ie. URLs) in the vector
7f561c08de6b Initial load
duke
parents:
diff changeset
   462
        final int count = stylesheets.size();
7f561c08de6b Initial load
duke
parents:
diff changeset
   463
7f561c08de6b Initial load
duke
parents:
diff changeset
   464
        // Return straight away if the vector is empty
7f561c08de6b Initial load
duke
parents:
diff changeset
   465
        if (count == 0) return true;
7f561c08de6b Initial load
duke
parents:
diff changeset
   466
7f561c08de6b Initial load
duke
parents:
diff changeset
   467
        // Special handling needed if the URL count is one, becuase the
7f561c08de6b Initial load
duke
parents:
diff changeset
   468
        // _className global must not be reset if it was set explicitly
7f561c08de6b Initial load
duke
parents:
diff changeset
   469
        if (count == 1) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   470
            final Object url = stylesheets.firstElement();
7f561c08de6b Initial load
duke
parents:
diff changeset
   471
            if (url instanceof URL)
7f561c08de6b Initial load
duke
parents:
diff changeset
   472
                return compile((URL)url);
7f561c08de6b Initial load
duke
parents:
diff changeset
   473
            else
7f561c08de6b Initial load
duke
parents:
diff changeset
   474
                return false;
7f561c08de6b Initial load
duke
parents:
diff changeset
   475
        }
7f561c08de6b Initial load
duke
parents:
diff changeset
   476
        else {
7f561c08de6b Initial load
duke
parents:
diff changeset
   477
            // Traverse all elements in the vector and compile
7f561c08de6b Initial load
duke
parents:
diff changeset
   478
            final Enumeration urls = stylesheets.elements();
7f561c08de6b Initial load
duke
parents:
diff changeset
   479
            while (urls.hasMoreElements()) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   480
                _className = null; // reset, so that new name will be computed
7f561c08de6b Initial load
duke
parents:
diff changeset
   481
                final Object url = urls.nextElement();
7f561c08de6b Initial load
duke
parents:
diff changeset
   482
                if (url instanceof URL) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   483
                    if (!compile((URL)url)) return false;
7f561c08de6b Initial load
duke
parents:
diff changeset
   484
                }
7f561c08de6b Initial load
duke
parents:
diff changeset
   485
            }
7f561c08de6b Initial load
duke
parents:
diff changeset
   486
        }
7f561c08de6b Initial load
duke
parents:
diff changeset
   487
        return true;
7f561c08de6b Initial load
duke
parents:
diff changeset
   488
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   489
7f561c08de6b Initial load
duke
parents:
diff changeset
   490
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   491
     * Returns an array of bytecode arrays generated by a compilation.
7f561c08de6b Initial load
duke
parents:
diff changeset
   492
     * @return JVM bytecodes that represent translet class definition
7f561c08de6b Initial load
duke
parents:
diff changeset
   493
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   494
    public byte[][] getBytecodes() {
7f561c08de6b Initial load
duke
parents:
diff changeset
   495
        final int count = _classes.size();
7f561c08de6b Initial load
duke
parents:
diff changeset
   496
        final byte[][] result = new byte[count][1];
7f561c08de6b Initial load
duke
parents:
diff changeset
   497
        for (int i = 0; i < count; i++)
7f561c08de6b Initial load
duke
parents:
diff changeset
   498
            result[i] = (byte[])_classes.elementAt(i);
7f561c08de6b Initial load
duke
parents:
diff changeset
   499
        return result;
7f561c08de6b Initial load
duke
parents:
diff changeset
   500
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   501
7f561c08de6b Initial load
duke
parents:
diff changeset
   502
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   503
     * Compiles a stylesheet pointed to by a URL. The result is put in a
7f561c08de6b Initial load
duke
parents:
diff changeset
   504
     * set of byte arrays. One byte array for each generated class.
7f561c08de6b Initial load
duke
parents:
diff changeset
   505
     * @param name The name of the translet class to generate
7f561c08de6b Initial load
duke
parents:
diff changeset
   506
     * @param input An InputSource that will pass in the stylesheet contents
7f561c08de6b Initial load
duke
parents:
diff changeset
   507
     * @param outputType The output type
7f561c08de6b Initial load
duke
parents:
diff changeset
   508
     * @return JVM bytecodes that represent translet class definition
7f561c08de6b Initial load
duke
parents:
diff changeset
   509
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   510
    public byte[][] compile(String name, InputSource input, int outputType) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   511
        _outputType = outputType;
7f561c08de6b Initial load
duke
parents:
diff changeset
   512
        if (compile(input, name))
7f561c08de6b Initial load
duke
parents:
diff changeset
   513
            return getBytecodes();
7f561c08de6b Initial load
duke
parents:
diff changeset
   514
        else
7f561c08de6b Initial load
duke
parents:
diff changeset
   515
            return null;
7f561c08de6b Initial load
duke
parents:
diff changeset
   516
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   517
7f561c08de6b Initial load
duke
parents:
diff changeset
   518
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   519
     * Compiles a stylesheet pointed to by a URL. The result is put in a
7f561c08de6b Initial load
duke
parents:
diff changeset
   520
     * set of byte arrays. One byte array for each generated class.
7f561c08de6b Initial load
duke
parents:
diff changeset
   521
     * @param name The name of the translet class to generate
7f561c08de6b Initial load
duke
parents:
diff changeset
   522
     * @param input An InputSource that will pass in the stylesheet contents
7f561c08de6b Initial load
duke
parents:
diff changeset
   523
     * @return JVM bytecodes that represent translet class definition
7f561c08de6b Initial load
duke
parents:
diff changeset
   524
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   525
    public byte[][] compile(String name, InputSource input) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   526
        return compile(name, input, BYTEARRAY_OUTPUT);
7f561c08de6b Initial load
duke
parents:
diff changeset
   527
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   528
7f561c08de6b Initial load
duke
parents:
diff changeset
   529
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   530
     * Set the XMLReader to use for parsing the next input stylesheet
7f561c08de6b Initial load
duke
parents:
diff changeset
   531
     * @param reader XMLReader (SAX2 parser) to use
7f561c08de6b Initial load
duke
parents:
diff changeset
   532
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   533
    public void setXMLReader(XMLReader reader) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   534
        _reader = reader;
7f561c08de6b Initial load
duke
parents:
diff changeset
   535
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   536
7f561c08de6b Initial load
duke
parents:
diff changeset
   537
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   538
     * Get the XMLReader to use for parsing the next input stylesheet
7f561c08de6b Initial load
duke
parents:
diff changeset
   539
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   540
    public XMLReader getXMLReader() {
7f561c08de6b Initial load
duke
parents:
diff changeset
   541
        return _reader ;
7f561c08de6b Initial load
duke
parents:
diff changeset
   542
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   543
7f561c08de6b Initial load
duke
parents:
diff changeset
   544
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   545
     * Get a Vector containing all compile error messages
7f561c08de6b Initial load
duke
parents:
diff changeset
   546
     * @return A Vector containing all compile error messages
7f561c08de6b Initial load
duke
parents:
diff changeset
   547
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   548
    public Vector getErrors() {
7f561c08de6b Initial load
duke
parents:
diff changeset
   549
        return _parser.getErrors();
7f561c08de6b Initial load
duke
parents:
diff changeset
   550
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   551
7f561c08de6b Initial load
duke
parents:
diff changeset
   552
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   553
     * Get a Vector containing all compile warning messages
7f561c08de6b Initial load
duke
parents:
diff changeset
   554
     * @return A Vector containing all compile error messages
7f561c08de6b Initial load
duke
parents:
diff changeset
   555
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   556
    public Vector getWarnings() {
7f561c08de6b Initial load
duke
parents:
diff changeset
   557
        return _parser.getWarnings();
7f561c08de6b Initial load
duke
parents:
diff changeset
   558
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   559
7f561c08de6b Initial load
duke
parents:
diff changeset
   560
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   561
     * Print all compile error messages to standard output
7f561c08de6b Initial load
duke
parents:
diff changeset
   562
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   563
    public void printErrors() {
7f561c08de6b Initial load
duke
parents:
diff changeset
   564
        _parser.printErrors();
7f561c08de6b Initial load
duke
parents:
diff changeset
   565
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   566
7f561c08de6b Initial load
duke
parents:
diff changeset
   567
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   568
     * Print all compile warning messages to standard output
7f561c08de6b Initial load
duke
parents:
diff changeset
   569
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   570
    public void printWarnings() {
7f561c08de6b Initial load
duke
parents:
diff changeset
   571
        _parser.printWarnings();
7f561c08de6b Initial load
duke
parents:
diff changeset
   572
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   573
7f561c08de6b Initial load
duke
parents:
diff changeset
   574
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   575
     * This method is called by the XPathParser when it encounters a call
7f561c08de6b Initial load
duke
parents:
diff changeset
   576
     * to the document() function. Affects the DOM used by the translet.
7f561c08de6b Initial load
duke
parents:
diff changeset
   577
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   578
    protected void setMultiDocument(boolean flag) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   579
        _multiDocument = flag;
7f561c08de6b Initial load
duke
parents:
diff changeset
   580
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   581
7f561c08de6b Initial load
duke
parents:
diff changeset
   582
    public boolean isMultiDocument() {
7f561c08de6b Initial load
duke
parents:
diff changeset
   583
        return _multiDocument;
7f561c08de6b Initial load
duke
parents:
diff changeset
   584
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   585
7f561c08de6b Initial load
duke
parents:
diff changeset
   586
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   587
     * This method is called by the XPathParser when it encounters a call
7f561c08de6b Initial load
duke
parents:
diff changeset
   588
     * to the nodeset() extension function. Implies multi document.
7f561c08de6b Initial load
duke
parents:
diff changeset
   589
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   590
    protected void setCallsNodeset(boolean flag) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   591
        if (flag) setMultiDocument(flag);
7f561c08de6b Initial load
duke
parents:
diff changeset
   592
        _callsNodeset = flag;
7f561c08de6b Initial load
duke
parents:
diff changeset
   593
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   594
7f561c08de6b Initial load
duke
parents:
diff changeset
   595
    public boolean callsNodeset() {
7f561c08de6b Initial load
duke
parents:
diff changeset
   596
        return _callsNodeset;
7f561c08de6b Initial load
duke
parents:
diff changeset
   597
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   598
7f561c08de6b Initial load
duke
parents:
diff changeset
   599
    protected void setHasIdCall(boolean flag) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   600
        _hasIdCall = flag;
7f561c08de6b Initial load
duke
parents:
diff changeset
   601
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   602
7f561c08de6b Initial load
duke
parents:
diff changeset
   603
    public boolean hasIdCall() {
7f561c08de6b Initial load
duke
parents:
diff changeset
   604
        return _hasIdCall;
7f561c08de6b Initial load
duke
parents:
diff changeset
   605
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   606
7f561c08de6b Initial load
duke
parents:
diff changeset
   607
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   608
     * Set the class name for the generated translet. This class name is
7f561c08de6b Initial load
duke
parents:
diff changeset
   609
     * overridden if multiple stylesheets are compiled in one go using the
7f561c08de6b Initial load
duke
parents:
diff changeset
   610
     * compile(Vector urls) method.
7f561c08de6b Initial load
duke
parents:
diff changeset
   611
     * @param className The name to assign to the translet class
7f561c08de6b Initial load
duke
parents:
diff changeset
   612
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   613
    public void setClassName(String className) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   614
        final String base  = Util.baseName(className);
7f561c08de6b Initial load
duke
parents:
diff changeset
   615
        final String noext = Util.noExtName(base);
7f561c08de6b Initial load
duke
parents:
diff changeset
   616
        String name  = Util.toJavaName(noext);
7f561c08de6b Initial load
duke
parents:
diff changeset
   617
7f561c08de6b Initial load
duke
parents:
diff changeset
   618
        if (_packageName == null)
7f561c08de6b Initial load
duke
parents:
diff changeset
   619
            _className = name;
7f561c08de6b Initial load
duke
parents:
diff changeset
   620
        else
7f561c08de6b Initial load
duke
parents:
diff changeset
   621
            _className = _packageName + '.' + name;
7f561c08de6b Initial load
duke
parents:
diff changeset
   622
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   623
7f561c08de6b Initial load
duke
parents:
diff changeset
   624
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   625
     * Get the class name for the generated translet.
7f561c08de6b Initial load
duke
parents:
diff changeset
   626
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   627
    public String getClassName() {
7f561c08de6b Initial load
duke
parents:
diff changeset
   628
        return _className;
7f561c08de6b Initial load
duke
parents:
diff changeset
   629
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   630
7f561c08de6b Initial load
duke
parents:
diff changeset
   631
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   632
     * Convert for Java class name of local system file name.
7f561c08de6b Initial load
duke
parents:
diff changeset
   633
     * (Replace '.' with '/' on UNIX and replace '.' by '\' on Windows/DOS.)
7f561c08de6b Initial load
duke
parents:
diff changeset
   634
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   635
    private String classFileName(final String className) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   636
        return className.replace('.', File.separatorChar) + ".class";
7f561c08de6b Initial load
duke
parents:
diff changeset
   637
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   638
7f561c08de6b Initial load
duke
parents:
diff changeset
   639
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   640
     * Generate an output File object to send the translet to
7f561c08de6b Initial load
duke
parents:
diff changeset
   641
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   642
    private File getOutputFile(String className) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   643
        if (_destDir != null)
7f561c08de6b Initial load
duke
parents:
diff changeset
   644
            return new File(_destDir, classFileName(className));
7f561c08de6b Initial load
duke
parents:
diff changeset
   645
        else
7f561c08de6b Initial load
duke
parents:
diff changeset
   646
            return new File(classFileName(className));
7f561c08de6b Initial load
duke
parents:
diff changeset
   647
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   648
7f561c08de6b Initial load
duke
parents:
diff changeset
   649
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   650
     * Set the destination directory for the translet.
7f561c08de6b Initial load
duke
parents:
diff changeset
   651
     * The current working directory will be used by default.
7f561c08de6b Initial load
duke
parents:
diff changeset
   652
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   653
    public boolean setDestDirectory(String dstDirName) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   654
        final File dir = new File(dstDirName);
16953
a44e04deb948 6657673: Issues with JAXP
joehw
parents: 12458
diff changeset
   655
        if (SecuritySupport.getFileExists(dir) || dir.mkdirs()) {
6
7f561c08de6b Initial load
duke
parents:
diff changeset
   656
            _destDir = dir;
7f561c08de6b Initial load
duke
parents:
diff changeset
   657
            return true;
7f561c08de6b Initial load
duke
parents:
diff changeset
   658
        }
7f561c08de6b Initial load
duke
parents:
diff changeset
   659
        else {
7f561c08de6b Initial load
duke
parents:
diff changeset
   660
            _destDir = null;
7f561c08de6b Initial load
duke
parents:
diff changeset
   661
            return false;
7f561c08de6b Initial load
duke
parents:
diff changeset
   662
        }
7f561c08de6b Initial load
duke
parents:
diff changeset
   663
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   664
7f561c08de6b Initial load
duke
parents:
diff changeset
   665
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   666
     * Set an optional package name for the translet and auxiliary classes
7f561c08de6b Initial load
duke
parents:
diff changeset
   667
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   668
    public void setPackageName(String packageName) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   669
        _packageName = packageName;
7f561c08de6b Initial load
duke
parents:
diff changeset
   670
        if (_className != null) setClassName(_className);
7f561c08de6b Initial load
duke
parents:
diff changeset
   671
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   672
7f561c08de6b Initial load
duke
parents:
diff changeset
   673
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   674
     * Set the name of an optional JAR-file to dump the translet and
7f561c08de6b Initial load
duke
parents:
diff changeset
   675
     * auxiliary classes to
7f561c08de6b Initial load
duke
parents:
diff changeset
   676
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   677
    public void setJarFileName(String jarFileName) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   678
        final String JAR_EXT = ".jar";
7f561c08de6b Initial load
duke
parents:
diff changeset
   679
        if (jarFileName.endsWith(JAR_EXT))
7f561c08de6b Initial load
duke
parents:
diff changeset
   680
            _jarFileName = jarFileName;
7f561c08de6b Initial load
duke
parents:
diff changeset
   681
        else
7f561c08de6b Initial load
duke
parents:
diff changeset
   682
            _jarFileName = jarFileName + JAR_EXT;
7f561c08de6b Initial load
duke
parents:
diff changeset
   683
        _outputType = JAR_OUTPUT;
7f561c08de6b Initial load
duke
parents:
diff changeset
   684
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   685
7f561c08de6b Initial load
duke
parents:
diff changeset
   686
    public String getJarFileName() {
7f561c08de6b Initial load
duke
parents:
diff changeset
   687
        return _jarFileName;
7f561c08de6b Initial load
duke
parents:
diff changeset
   688
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   689
7f561c08de6b Initial load
duke
parents:
diff changeset
   690
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   691
     * Set the top-level stylesheet
7f561c08de6b Initial load
duke
parents:
diff changeset
   692
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   693
    public void setStylesheet(Stylesheet stylesheet) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   694
        if (_stylesheet == null) _stylesheet = stylesheet;
7f561c08de6b Initial load
duke
parents:
diff changeset
   695
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   696
7f561c08de6b Initial load
duke
parents:
diff changeset
   697
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   698
     * Returns the top-level stylesheet
7f561c08de6b Initial load
duke
parents:
diff changeset
   699
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   700
    public Stylesheet getStylesheet() {
7f561c08de6b Initial load
duke
parents:
diff changeset
   701
        return _stylesheet;
7f561c08de6b Initial load
duke
parents:
diff changeset
   702
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   703
7f561c08de6b Initial load
duke
parents:
diff changeset
   704
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   705
     * Registers an attribute and gives it a type so that it can be mapped to
7f561c08de6b Initial load
duke
parents:
diff changeset
   706
     * DOM attribute types at run-time.
7f561c08de6b Initial load
duke
parents:
diff changeset
   707
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   708
    public int registerAttribute(QName name) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   709
        Integer code = (Integer)_attributes.get(name.toString());
7f561c08de6b Initial load
duke
parents:
diff changeset
   710
        if (code == null) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   711
            code = new Integer(_nextGType++);
7f561c08de6b Initial load
duke
parents:
diff changeset
   712
            _attributes.put(name.toString(), code);
7f561c08de6b Initial load
duke
parents:
diff changeset
   713
            final String uri = name.getNamespace();
7f561c08de6b Initial load
duke
parents:
diff changeset
   714
            final String local = "@"+name.getLocalPart();
7f561c08de6b Initial load
duke
parents:
diff changeset
   715
            if ((uri != null) && (!uri.equals("")))
7f561c08de6b Initial load
duke
parents:
diff changeset
   716
                _namesIndex.addElement(uri+":"+local);
7f561c08de6b Initial load
duke
parents:
diff changeset
   717
            else
7f561c08de6b Initial load
duke
parents:
diff changeset
   718
                _namesIndex.addElement(local);
7f561c08de6b Initial load
duke
parents:
diff changeset
   719
            if (name.getLocalPart().equals("*")) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   720
                registerNamespace(name.getNamespace());
7f561c08de6b Initial load
duke
parents:
diff changeset
   721
            }
7f561c08de6b Initial load
duke
parents:
diff changeset
   722
        }
7f561c08de6b Initial load
duke
parents:
diff changeset
   723
        return code.intValue();
7f561c08de6b Initial load
duke
parents:
diff changeset
   724
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   725
7f561c08de6b Initial load
duke
parents:
diff changeset
   726
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   727
     * Registers an element and gives it a type so that it can be mapped to
7f561c08de6b Initial load
duke
parents:
diff changeset
   728
     * DOM element types at run-time.
7f561c08de6b Initial load
duke
parents:
diff changeset
   729
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   730
    public int registerElement(QName name) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   731
        // Register element (full QName)
7f561c08de6b Initial load
duke
parents:
diff changeset
   732
        Integer code = (Integer)_elements.get(name.toString());
7f561c08de6b Initial load
duke
parents:
diff changeset
   733
        if (code == null) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   734
            _elements.put(name.toString(), code = new Integer(_nextGType++));
7f561c08de6b Initial load
duke
parents:
diff changeset
   735
            _namesIndex.addElement(name.toString());
7f561c08de6b Initial load
duke
parents:
diff changeset
   736
        }
7f561c08de6b Initial load
duke
parents:
diff changeset
   737
        if (name.getLocalPart().equals("*")) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   738
            registerNamespace(name.getNamespace());
7f561c08de6b Initial load
duke
parents:
diff changeset
   739
        }
7f561c08de6b Initial load
duke
parents:
diff changeset
   740
        return code.intValue();
7f561c08de6b Initial load
duke
parents:
diff changeset
   741
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   742
7f561c08de6b Initial load
duke
parents:
diff changeset
   743
     /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   744
      * Registers a namespace prefix and gives it a type so that it can be mapped to
7f561c08de6b Initial load
duke
parents:
diff changeset
   745
      * DOM namespace types at run-time.
7f561c08de6b Initial load
duke
parents:
diff changeset
   746
      */
7f561c08de6b Initial load
duke
parents:
diff changeset
   747
7f561c08de6b Initial load
duke
parents:
diff changeset
   748
    public int registerNamespacePrefix(QName name) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   749
7f561c08de6b Initial load
duke
parents:
diff changeset
   750
    Integer code = (Integer)_namespacePrefixes.get(name.toString());
7f561c08de6b Initial load
duke
parents:
diff changeset
   751
    if (code == null) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   752
        code = new Integer(_nextGType++);
7f561c08de6b Initial load
duke
parents:
diff changeset
   753
        _namespacePrefixes.put(name.toString(), code);
7f561c08de6b Initial load
duke
parents:
diff changeset
   754
        final String uri = name.getNamespace();
7f561c08de6b Initial load
duke
parents:
diff changeset
   755
        if ((uri != null) && (!uri.equals(""))){
7f561c08de6b Initial load
duke
parents:
diff changeset
   756
            // namespace::ext2:ped2 will be made empty in TypedNamespaceIterator
7f561c08de6b Initial load
duke
parents:
diff changeset
   757
            _namesIndex.addElement("?");
7f561c08de6b Initial load
duke
parents:
diff changeset
   758
        } else{
7f561c08de6b Initial load
duke
parents:
diff changeset
   759
           _namesIndex.addElement("?"+name.getLocalPart());
7f561c08de6b Initial load
duke
parents:
diff changeset
   760
        }
7f561c08de6b Initial load
duke
parents:
diff changeset
   761
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   762
    return code.intValue();
7f561c08de6b Initial load
duke
parents:
diff changeset
   763
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   764
7f561c08de6b Initial load
duke
parents:
diff changeset
   765
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   766
     * Registers a namespace and gives it a type so that it can be mapped to
7f561c08de6b Initial load
duke
parents:
diff changeset
   767
     * DOM namespace types at run-time.
7f561c08de6b Initial load
duke
parents:
diff changeset
   768
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   769
    public int registerNamespace(String namespaceURI) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   770
        Integer code = (Integer)_namespaces.get(namespaceURI);
7f561c08de6b Initial load
duke
parents:
diff changeset
   771
        if (code == null) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   772
            code = new Integer(_nextNSType++);
7f561c08de6b Initial load
duke
parents:
diff changeset
   773
            _namespaces.put(namespaceURI,code);
7f561c08de6b Initial load
duke
parents:
diff changeset
   774
            _namespaceIndex.addElement(namespaceURI);
7f561c08de6b Initial load
duke
parents:
diff changeset
   775
        }
7f561c08de6b Initial load
duke
parents:
diff changeset
   776
        return code.intValue();
7f561c08de6b Initial load
duke
parents:
diff changeset
   777
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   778
7f561c08de6b Initial load
duke
parents:
diff changeset
   779
    public int nextModeSerial() {
7f561c08de6b Initial load
duke
parents:
diff changeset
   780
        return _modeSerial++;
7f561c08de6b Initial load
duke
parents:
diff changeset
   781
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   782
7f561c08de6b Initial load
duke
parents:
diff changeset
   783
    public int nextStylesheetSerial() {
7f561c08de6b Initial load
duke
parents:
diff changeset
   784
        return _stylesheetSerial++;
7f561c08de6b Initial load
duke
parents:
diff changeset
   785
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   786
7f561c08de6b Initial load
duke
parents:
diff changeset
   787
    public int nextStepPatternSerial() {
7f561c08de6b Initial load
duke
parents:
diff changeset
   788
        return _stepPatternSerial++;
7f561c08de6b Initial load
duke
parents:
diff changeset
   789
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   790
7f561c08de6b Initial load
duke
parents:
diff changeset
   791
    public int[] getNumberFieldIndexes() {
7f561c08de6b Initial load
duke
parents:
diff changeset
   792
        return _numberFieldIndexes;
7f561c08de6b Initial load
duke
parents:
diff changeset
   793
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   794
7f561c08de6b Initial load
duke
parents:
diff changeset
   795
    public int nextHelperClassSerial() {
7f561c08de6b Initial load
duke
parents:
diff changeset
   796
        return _helperClassSerial++;
7f561c08de6b Initial load
duke
parents:
diff changeset
   797
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   798
7f561c08de6b Initial load
duke
parents:
diff changeset
   799
    public int nextAttributeSetSerial() {
7f561c08de6b Initial load
duke
parents:
diff changeset
   800
        return _attributeSetSerial++;
7f561c08de6b Initial load
duke
parents:
diff changeset
   801
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   802
7f561c08de6b Initial load
duke
parents:
diff changeset
   803
    public Vector getNamesIndex() {
7f561c08de6b Initial load
duke
parents:
diff changeset
   804
        return _namesIndex;
7f561c08de6b Initial load
duke
parents:
diff changeset
   805
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   806
7f561c08de6b Initial load
duke
parents:
diff changeset
   807
    public Vector getNamespaceIndex() {
7f561c08de6b Initial load
duke
parents:
diff changeset
   808
        return _namespaceIndex;
7f561c08de6b Initial load
duke
parents:
diff changeset
   809
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   810
7f561c08de6b Initial load
duke
parents:
diff changeset
   811
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   812
     * Returns a unique name for every helper class needed to
7f561c08de6b Initial load
duke
parents:
diff changeset
   813
     * execute a translet.
7f561c08de6b Initial load
duke
parents:
diff changeset
   814
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   815
    public String getHelperClassName() {
7f561c08de6b Initial load
duke
parents:
diff changeset
   816
        return getClassName() + '$' + _helperClassSerial++;
7f561c08de6b Initial load
duke
parents:
diff changeset
   817
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   818
7f561c08de6b Initial load
duke
parents:
diff changeset
   819
    public void dumpClass(JavaClass clazz) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   820
7f561c08de6b Initial load
duke
parents:
diff changeset
   821
        if (_outputType == FILE_OUTPUT ||
7f561c08de6b Initial load
duke
parents:
diff changeset
   822
            _outputType == BYTEARRAY_AND_FILE_OUTPUT)
7f561c08de6b Initial load
duke
parents:
diff changeset
   823
        {
7f561c08de6b Initial load
duke
parents:
diff changeset
   824
            File outFile = getOutputFile(clazz.getClassName());
7f561c08de6b Initial load
duke
parents:
diff changeset
   825
            String parentDir = outFile.getParent();
7f561c08de6b Initial load
duke
parents:
diff changeset
   826
            if (parentDir != null) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   827
                File parentFile = new File(parentDir);
16953
a44e04deb948 6657673: Issues with JAXP
joehw
parents: 12458
diff changeset
   828
                if (!SecuritySupport.getFileExists(parentFile))
6
7f561c08de6b Initial load
duke
parents:
diff changeset
   829
                    parentFile.mkdirs();
7f561c08de6b Initial load
duke
parents:
diff changeset
   830
            }
7f561c08de6b Initial load
duke
parents:
diff changeset
   831
        }
7f561c08de6b Initial load
duke
parents:
diff changeset
   832
7f561c08de6b Initial load
duke
parents:
diff changeset
   833
        try {
7f561c08de6b Initial load
duke
parents:
diff changeset
   834
            switch (_outputType) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   835
            case FILE_OUTPUT:
7f561c08de6b Initial load
duke
parents:
diff changeset
   836
                clazz.dump(
7f561c08de6b Initial load
duke
parents:
diff changeset
   837
                    new BufferedOutputStream(
7f561c08de6b Initial load
duke
parents:
diff changeset
   838
                        new FileOutputStream(
7f561c08de6b Initial load
duke
parents:
diff changeset
   839
                            getOutputFile(clazz.getClassName()))));
7f561c08de6b Initial load
duke
parents:
diff changeset
   840
                break;
7f561c08de6b Initial load
duke
parents:
diff changeset
   841
            case JAR_OUTPUT:
7f561c08de6b Initial load
duke
parents:
diff changeset
   842
                _bcelClasses.addElement(clazz);
7f561c08de6b Initial load
duke
parents:
diff changeset
   843
                break;
7f561c08de6b Initial load
duke
parents:
diff changeset
   844
            case BYTEARRAY_OUTPUT:
7f561c08de6b Initial load
duke
parents:
diff changeset
   845
            case BYTEARRAY_AND_FILE_OUTPUT:
7f561c08de6b Initial load
duke
parents:
diff changeset
   846
            case BYTEARRAY_AND_JAR_OUTPUT:
7f561c08de6b Initial load
duke
parents:
diff changeset
   847
            case CLASSLOADER_OUTPUT:
7f561c08de6b Initial load
duke
parents:
diff changeset
   848
                ByteArrayOutputStream out = new ByteArrayOutputStream(2048);
7f561c08de6b Initial load
duke
parents:
diff changeset
   849
                clazz.dump(out);
7f561c08de6b Initial load
duke
parents:
diff changeset
   850
                _classes.addElement(out.toByteArray());
7f561c08de6b Initial load
duke
parents:
diff changeset
   851
7f561c08de6b Initial load
duke
parents:
diff changeset
   852
                if (_outputType == BYTEARRAY_AND_FILE_OUTPUT)
7f561c08de6b Initial load
duke
parents:
diff changeset
   853
                  clazz.dump(new BufferedOutputStream(
7f561c08de6b Initial load
duke
parents:
diff changeset
   854
                        new FileOutputStream(getOutputFile(clazz.getClassName()))));
7f561c08de6b Initial load
duke
parents:
diff changeset
   855
                else if (_outputType == BYTEARRAY_AND_JAR_OUTPUT)
7f561c08de6b Initial load
duke
parents:
diff changeset
   856
                  _bcelClasses.addElement(clazz);
7f561c08de6b Initial load
duke
parents:
diff changeset
   857
7f561c08de6b Initial load
duke
parents:
diff changeset
   858
                break;
7f561c08de6b Initial load
duke
parents:
diff changeset
   859
            }
7f561c08de6b Initial load
duke
parents:
diff changeset
   860
        }
7f561c08de6b Initial load
duke
parents:
diff changeset
   861
        catch (Exception e) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   862
            e.printStackTrace();
7f561c08de6b Initial load
duke
parents:
diff changeset
   863
        }
7f561c08de6b Initial load
duke
parents:
diff changeset
   864
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   865
7f561c08de6b Initial load
duke
parents:
diff changeset
   866
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   867
     * File separators are converted to forward slashes for ZIP files.
7f561c08de6b Initial load
duke
parents:
diff changeset
   868
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   869
    private String entryName(File f) throws IOException {
7f561c08de6b Initial load
duke
parents:
diff changeset
   870
        return f.getName().replace(File.separatorChar, '/');
7f561c08de6b Initial load
duke
parents:
diff changeset
   871
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   872
7f561c08de6b Initial load
duke
parents:
diff changeset
   873
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   874
     * Generate output JAR-file and packages
7f561c08de6b Initial load
duke
parents:
diff changeset
   875
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   876
    public void outputToJar() throws IOException {
7f561c08de6b Initial load
duke
parents:
diff changeset
   877
        // create the manifest
7f561c08de6b Initial load
duke
parents:
diff changeset
   878
        final Manifest manifest = new Manifest();
7f561c08de6b Initial load
duke
parents:
diff changeset
   879
        final java.util.jar.Attributes atrs = manifest.getMainAttributes();
7f561c08de6b Initial load
duke
parents:
diff changeset
   880
        atrs.put(java.util.jar.Attributes.Name.MANIFEST_VERSION,"1.2");
7f561c08de6b Initial load
duke
parents:
diff changeset
   881
7f561c08de6b Initial load
duke
parents:
diff changeset
   882
        final Map map = manifest.getEntries();
7f561c08de6b Initial load
duke
parents:
diff changeset
   883
        // create manifest
7f561c08de6b Initial load
duke
parents:
diff changeset
   884
        Enumeration classes = _bcelClasses.elements();
7f561c08de6b Initial load
duke
parents:
diff changeset
   885
        final String now = (new Date()).toString();
7f561c08de6b Initial load
duke
parents:
diff changeset
   886
        final java.util.jar.Attributes.Name dateAttr =
7f561c08de6b Initial load
duke
parents:
diff changeset
   887
            new java.util.jar.Attributes.Name("Date");
7f561c08de6b Initial load
duke
parents:
diff changeset
   888
        while (classes.hasMoreElements()) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   889
            final JavaClass clazz = (JavaClass)classes.nextElement();
7f561c08de6b Initial load
duke
parents:
diff changeset
   890
            final String className = clazz.getClassName().replace('.','/');
7f561c08de6b Initial load
duke
parents:
diff changeset
   891
            final java.util.jar.Attributes attr = new java.util.jar.Attributes();
7f561c08de6b Initial load
duke
parents:
diff changeset
   892
            attr.put(dateAttr, now);
7f561c08de6b Initial load
duke
parents:
diff changeset
   893
            map.put(className+".class", attr);
7f561c08de6b Initial load
duke
parents:
diff changeset
   894
        }
7f561c08de6b Initial load
duke
parents:
diff changeset
   895
7f561c08de6b Initial load
duke
parents:
diff changeset
   896
        final File jarFile = new File(_destDir, _jarFileName);
7f561c08de6b Initial load
duke
parents:
diff changeset
   897
        final JarOutputStream jos =
7f561c08de6b Initial load
duke
parents:
diff changeset
   898
            new JarOutputStream(new FileOutputStream(jarFile), manifest);
7f561c08de6b Initial load
duke
parents:
diff changeset
   899
        classes = _bcelClasses.elements();
7f561c08de6b Initial load
duke
parents:
diff changeset
   900
        while (classes.hasMoreElements()) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   901
            final JavaClass clazz = (JavaClass)classes.nextElement();
7f561c08de6b Initial load
duke
parents:
diff changeset
   902
            final String className = clazz.getClassName().replace('.','/');
7f561c08de6b Initial load
duke
parents:
diff changeset
   903
            jos.putNextEntry(new JarEntry(className+".class"));
7f561c08de6b Initial load
duke
parents:
diff changeset
   904
            final ByteArrayOutputStream out = new ByteArrayOutputStream(2048);
7f561c08de6b Initial load
duke
parents:
diff changeset
   905
            clazz.dump(out); // dump() closes it's output stream
7f561c08de6b Initial load
duke
parents:
diff changeset
   906
            out.writeTo(jos);
7f561c08de6b Initial load
duke
parents:
diff changeset
   907
        }
7f561c08de6b Initial load
duke
parents:
diff changeset
   908
        jos.close();
7f561c08de6b Initial load
duke
parents:
diff changeset
   909
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   910
7f561c08de6b Initial load
duke
parents:
diff changeset
   911
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   912
     * Turn debugging messages on/off
7f561c08de6b Initial load
duke
parents:
diff changeset
   913
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   914
    public void setDebug(boolean debug) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   915
        _debug = debug;
7f561c08de6b Initial load
duke
parents:
diff changeset
   916
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   917
7f561c08de6b Initial load
duke
parents:
diff changeset
   918
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   919
     * Get current debugging message setting
7f561c08de6b Initial load
duke
parents:
diff changeset
   920
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   921
    public boolean debug() {
7f561c08de6b Initial load
duke
parents:
diff changeset
   922
        return _debug;
7f561c08de6b Initial load
duke
parents:
diff changeset
   923
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   924
7f561c08de6b Initial load
duke
parents:
diff changeset
   925
7f561c08de6b Initial load
duke
parents:
diff changeset
   926
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   927
     * Retrieve a string representation of the character data to be stored
7f561c08de6b Initial load
duke
parents:
diff changeset
   928
     * in the translet as a <code>char[]</code>.  There may be more than
7f561c08de6b Initial load
duke
parents:
diff changeset
   929
     * one such array required.
7f561c08de6b Initial load
duke
parents:
diff changeset
   930
     * @param index The index of the <code>char[]</code>.  Zero-based.
7f561c08de6b Initial load
duke
parents:
diff changeset
   931
     * @return String The character data to be stored in the corresponding
7f561c08de6b Initial load
duke
parents:
diff changeset
   932
     *               <code>char[]</code>.
7f561c08de6b Initial load
duke
parents:
diff changeset
   933
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   934
    public String getCharacterData(int index) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   935
        return ((StringBuffer) m_characterData.elementAt(index)).toString();
7f561c08de6b Initial load
duke
parents:
diff changeset
   936
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   937
7f561c08de6b Initial load
duke
parents:
diff changeset
   938
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   939
     * Get the number of char[] arrays, thus far, that will be created to
7f561c08de6b Initial load
duke
parents:
diff changeset
   940
     * store literal text in the stylesheet.
7f561c08de6b Initial load
duke
parents:
diff changeset
   941
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   942
    public int getCharacterDataCount() {
7f561c08de6b Initial load
duke
parents:
diff changeset
   943
        return (m_characterData != null) ? m_characterData.size() : 0;
7f561c08de6b Initial load
duke
parents:
diff changeset
   944
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   945
7f561c08de6b Initial load
duke
parents:
diff changeset
   946
    /**
7f561c08de6b Initial load
duke
parents:
diff changeset
   947
     * Add literal text to char arrays that will be used to store character
7f561c08de6b Initial load
duke
parents:
diff changeset
   948
     * data in the stylesheet.
7f561c08de6b Initial load
duke
parents:
diff changeset
   949
     * @param newData String data to be added to char arrays.
7f561c08de6b Initial load
duke
parents:
diff changeset
   950
     *                Pre-condition:  <code>newData.length() &le; 21845</code>
7f561c08de6b Initial load
duke
parents:
diff changeset
   951
     * @return int offset at which character data will be stored
7f561c08de6b Initial load
duke
parents:
diff changeset
   952
     */
7f561c08de6b Initial load
duke
parents:
diff changeset
   953
    public int addCharacterData(String newData) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   954
        StringBuffer currData;
7f561c08de6b Initial load
duke
parents:
diff changeset
   955
        if (m_characterData == null) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   956
            m_characterData = new Vector();
7f561c08de6b Initial load
duke
parents:
diff changeset
   957
            currData = new StringBuffer();
7f561c08de6b Initial load
duke
parents:
diff changeset
   958
            m_characterData.addElement(currData);
7f561c08de6b Initial load
duke
parents:
diff changeset
   959
        } else {
7f561c08de6b Initial load
duke
parents:
diff changeset
   960
            currData = (StringBuffer) m_characterData
7f561c08de6b Initial load
duke
parents:
diff changeset
   961
                                           .elementAt(m_characterData.size()-1);
7f561c08de6b Initial load
duke
parents:
diff changeset
   962
        }
7f561c08de6b Initial load
duke
parents:
diff changeset
   963
7f561c08de6b Initial load
duke
parents:
diff changeset
   964
        // Character data could take up to three-times as much space when
7f561c08de6b Initial load
duke
parents:
diff changeset
   965
        // written to the class file as UTF-8.  The maximum size for a
7f561c08de6b Initial load
duke
parents:
diff changeset
   966
        // constant is 65535/3.  If we exceed that,
7f561c08de6b Initial load
duke
parents:
diff changeset
   967
        // (We really should use some "bin packing".)
7f561c08de6b Initial load
duke
parents:
diff changeset
   968
        if (newData.length() + currData.length() > 21845) {
7f561c08de6b Initial load
duke
parents:
diff changeset
   969
            currData = new StringBuffer();
7f561c08de6b Initial load
duke
parents:
diff changeset
   970
            m_characterData.addElement(currData);
7f561c08de6b Initial load
duke
parents:
diff changeset
   971
        }
7f561c08de6b Initial load
duke
parents:
diff changeset
   972
7f561c08de6b Initial load
duke
parents:
diff changeset
   973
        int newDataOffset = currData.length();
7f561c08de6b Initial load
duke
parents:
diff changeset
   974
        currData.append(newData);
7f561c08de6b Initial load
duke
parents:
diff changeset
   975
7f561c08de6b Initial load
duke
parents:
diff changeset
   976
        return newDataOffset;
7f561c08de6b Initial load
duke
parents:
diff changeset
   977
    }
7f561c08de6b Initial load
duke
parents:
diff changeset
   978
}