~ubuntu-branches/ubuntu/karmic/libxerces2-java/karmic

« back to all changes in this revision

Viewing changes to src/org/apache/xerces/impl/dv/util/HexBin.java

  • Committer: Bazaar Package Importer
  • Author(s): Matthias Klose
  • Date: 2006-12-04 17:37:55 UTC
  • mfrom: (2.1.2 etch)
  • Revision ID: james.westby@ubuntu.com-20061204173755-hb6ybrrrk097zhx7
Tags: 2.8.1-1ubuntu1
* Merge with Debian unstable; remaining changes:
  - Build -gcj package.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
/*
2
 
 * The Apache Software License, Version 1.1
3
 
 *
4
 
 *
5
 
 * Copyright (c) 1999-2002 The Apache Software Foundation.  All rights
6
 
 * reserved.
7
 
 *
8
 
 * Redistribution and use in source and binary forms, with or without
9
 
 * modification, are permitted provided that the following conditions
10
 
 * are met:
11
 
 *
12
 
 * 1. Redistributions of source code must retain the above copyright
13
 
 *    notice, this list of conditions and the following disclaimer.
14
 
 *
15
 
 * 2. Redistributions in binary form must reproduce the above copyright
16
 
 *    notice, this list of conditions and the following disclaimer in
17
 
 *    the documentation and/or other materials provided with the
18
 
 *    distribution.
19
 
 *
20
 
 * 3. The end-user documentation included with the redistribution,
21
 
 *    if any, must include the following acknowledgment:
22
 
 *       "This product includes software developed by the
23
 
 *        Apache Software Foundation (http://www.apache.org/)."
24
 
 *    Alternately, this acknowledgment may appear in the software itself,
25
 
 *    if and wherever such third-party acknowledgments normally appear.
26
 
 *
27
 
 * 4. The names "Xerces" and "Apache Software Foundation" must
28
 
 *    not be used to endorse or promote products derived from this
29
 
 *    software without prior written permission. For written
30
 
 *    permission, please contact apache@apache.org.
31
 
 *
32
 
 * 5. Products derived from this software may not be called "Apache",
33
 
 *    nor may "Apache" appear in their name, without prior written
34
 
 *    permission of the Apache Software Foundation.
35
 
 *
36
 
 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
37
 
 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
38
 
 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
39
 
 * DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
40
 
 * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
41
 
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
42
 
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
43
 
 * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
44
 
 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
45
 
 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
46
 
 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
47
 
 * SUCH DAMAGE.
48
 
 * ====================================================================
49
 
 *
50
 
 * This software consists of voluntary contributions made by many
51
 
 * individuals on behalf of the Apache Software Foundation and was
52
 
 * originally based on software copyright (c) 1999, International
53
 
 * Business Machines, Inc., http://www.apache.org.  For more
54
 
 * information on the Apache Software Foundation, please see
55
 
 * <http://www.apache.org/>.
 
2
 * Copyright 1999-2002,2004 The Apache Software Foundation.
 
3
 * 
 
4
 * Licensed under the Apache License, Version 2.0 (the "License");
 
5
 * you may not use this file except in compliance with the License.
 
6
 * You may obtain a copy of the License at
 
7
 * 
 
8
 *      http://www.apache.org/licenses/LICENSE-2.0
 
9
 * 
 
10
 * Unless required by applicable law or agreed to in writing, software
 
11
 * distributed under the License is distributed on an "AS IS" BASIS,
 
12
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 
13
 * See the License for the specific language governing permissions and
 
14
 * limitations under the License.
56
15
 */
57
16
 
58
17
package org.apache.xerces.impl.dv.util;
61
20
 * format validation
62
21
 *
63
22
 * This class encodes/decodes hexadecimal data
 
23
 * 
 
24
 * @xerces.internal  
 
25
 * 
64
26
 * @author Jeffrey Rodriguez
65
 
 * @version $Id: HexBin.java,v 1.8 2003/05/08 20:11:55 elena Exp $
 
27
 * @version $Id: HexBin.java 320108 2004-10-14 15:20:18Z mrglavas $
66
28
 */
67
29
public final class  HexBin {
68
 
    static private final int  BASELENGTH   = 255;
 
30
    static private final int  BASELENGTH   = 128;
69
31
    static private final int  LOOKUPLENGTH = 16;
70
32
    static final private byte [] hexNumberTable    = new byte[BASELENGTH];
71
33
    static final private char [] lookUpHexAlphabet = new char[LOOKUPLENGTH];
72
34
 
73
35
 
74
36
    static {
75
 
        for (int i = 0; i<BASELENGTH; i++ ) {
 
37
        for (int i = 0; i < BASELENGTH; i++ ) {
76
38
            hexNumberTable[i] = -1;
77
39
        }
78
40
        for ( int i = '9'; i >= '0'; i--) {
85
47
           hexNumberTable[i] = (byte) ( i-'a' + 10 );
86
48
        }
87
49
 
88
 
        for(int i = 0; i<10; i++ )
 
50
        for(int i = 0; i<10; i++ ) {
89
51
            lookUpHexAlphabet[i] = (char)('0'+i);
90
 
        for(int i = 10; i<=15; i++ )
 
52
        }
 
53
        for(int i = 10; i<=15; i++ ) {
91
54
            lookUpHexAlphabet[i] = (char)('A'+i -10);
 
55
        }
92
56
    }
93
57
 
94
58
    /**
95
59
     * Encode a byte array to hex string
96
60
     *
97
 
     * @param binaryData  array of byte to encode
98
 
     * @return return     encoded string
 
61
     * @param binaryData array of byte to encode
 
62
     * @return return encoded string
99
63
     */
100
64
    static public String encode(byte[] binaryData) {
101
65
        if (binaryData == null)
117
81
    /**
118
82
     * Decode hex string to a byte array
119
83
     *
120
 
     * @param binaryData  encoded string
121
 
     * @return return     array of byte to encode
 
84
     * @param encoded encoded string
 
85
     * @return return array of byte to encode
122
86
     */
123
87
    static public byte[] decode(String encoded) {
124
88
        if (encoded == null)
131
95
        int lengthDecode = lengthData / 2;
132
96
        byte[] decodedData = new byte[lengthDecode];
133
97
        byte temp1, temp2;
 
98
        char tempChar;
134
99
        for( int i = 0; i<lengthDecode; i++ ){
135
 
            temp1 = hexNumberTable[binaryData[i*2]];
 
100
            tempChar = binaryData[i*2];
 
101
            temp1 = (tempChar < BASELENGTH) ? hexNumberTable[tempChar] : -1;
136
102
            if (temp1 == -1)
137
103
                return null;
138
 
            temp2 = hexNumberTable[binaryData[i*2+1]];
 
104
            tempChar = binaryData[i*2+1];
 
105
            temp2 = (tempChar < BASELENGTH) ? hexNumberTable[tempChar] : -1;
139
106
            if (temp2 == -1)
140
107
                return null;
141
108
            decodedData[i] = (byte)((temp1 << 4) | temp2);