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