View Javadoc

1   package org.apache.maven.surefire.util.internal;
2   
3   /*
4    * Licensed to the Apache Software Foundation (ASF) under one
5    * or more contributor license agreements.  See the NOTICE file
6    * distributed with this work for additional information
7    * regarding copyright ownership.  The ASF licenses this file
8    * to you under the Apache License, Version 2.0 (the
9    * "License"); you may not use this file except in compliance
10   * with the License.  You may obtain a copy of the License at
11   *
12   *     http://www.apache.org/licenses/LICENSE-2.0
13   *
14   * Unless required by applicable law or agreed to in writing,
15   * software distributed under the License is distributed on an
16   * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
17   * KIND, either express or implied.  See the License for the
18   * specific language governing permissions and limitations
19   * under the License.
20   */
21  
22  /**
23   * @author Kristian Rosenvold
24   */
25  public class ByteBuffer
26  {
27      private final byte[] data;
28  
29      private int position;
30  
31      public ByteBuffer( int length )
32      {
33          this.data = new byte[length];
34      }
35  
36      public ByteBuffer( byte[] buf, int off, int len )
37      {
38          this.data = new byte[len];
39          append( buf, off, len );
40      }
41  
42  
43      public void append( char chararcter )
44      {
45          data[position++] = (byte) chararcter;
46      }
47  
48      public void append( byte chararcter )
49      {
50          data[position++] = chararcter;
51      }
52  
53      private static final byte comma = (byte) ',';
54  
55      public void comma()
56      {
57          data[position++] = comma;
58      }
59  
60  
61      public void advance( int i )
62      { // Oooh nice break of encapsulation
63          position += i;
64      }
65  
66      public void append( Integer integer )
67      {
68          toHex( integer.intValue() );
69      }
70  
71      /**
72       * Convert the integer to an unsigned number.
73       * @param i the value
74       */
75      private void toHex( int i )
76      {
77          byte[] buf = new byte[32];
78          int charPos = 32;
79          int radix = 1 << 4;
80          int mask = radix - 1;
81          do
82          {
83              buf[--charPos] = (byte) digits[i & mask];
84              i >>>= 4;
85          }
86          while ( i != 0 );
87  
88          append( buf, charPos, ( 32 - charPos ) );
89      }
90  
91      private final static char[] digits =
92          { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l',
93              'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z' };
94  
95  
96      public byte[] getData()
97      {
98          return data;
99      }
100 
101     public int getlength()
102     {
103         return position;
104     }
105 
106     public String toString()
107     {
108         return new String( data, 0, position );
109     }
110 
111     public static byte[] copy( byte[] src1, int off1, int len1 )
112     {
113         byte[] combined = new byte[len1];
114         int pos = 0;
115         for ( int i = off1; i < off1 + len1; i++ )
116         {
117             combined[pos++] = src1[i];
118         }
119         return combined;
120     }
121 
122     void append( byte[] src1, int off1, int len1 )
123     {
124         for ( int i = off1; i < off1 + len1; i++ )
125         {
126             data[position++] = src1[i];
127         }
128     }
129 
130     public static byte[] join( byte[] src1, int off1, int len1, byte[] src2, int off2, int len2 )
131     {
132         byte[] combined = new byte[len1 + len2];
133         int pos = 0;
134         for ( int i = off1; i < off1 + len1; i++ )
135         {
136             combined[pos++] = src1[i];
137         }
138         for ( int i = off2; i < off2 + len2; i++ )
139         {
140             combined[pos++] = src2[i];
141         }
142         return combined;
143     }
144 
145 }