File: ByteBuffer.java

package info (click to toggle)
libfonts-java 1.1.6.dfsg2-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, forky, sid, trixie
  • size: 6,288 kB
  • sloc: java: 11,495; xml: 1,578; makefile: 30
file content (143 lines) | stat: -rw-r--r-- 3,309 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
/*
 * This program is free software; you can redistribute it and/or modify it under the
 * terms of the GNU Lesser General Public License, version 2.1 as published by the Free Software
 * Foundation.
 *
 * You should have received a copy of the GNU Lesser General Public License along with this
 * program; if not, you can obtain a copy at http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html
 * or from the Free Software Foundation, Inc.,
 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
 *
 * This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
 * See the GNU Lesser General Public License for more details.
 *
 * Copyright (c) 2006 - 2009 Pentaho Corporation and Contributors.  All rights reserved.
 */

package org.pentaho.reporting.libraries.fonts.encoding;

import java.io.Serializable;

/**
 * A simple byte buffer. The length specifies the fill level of the data-array.
 *
 * @author Thomas Morgner
 */
public class ByteBuffer implements Serializable
{
  private byte[] data;
  private int offset;
  private int cursor;

  public ByteBuffer(final int length)
  {
    if (length < 0)
    {
      throw new IllegalArgumentException();
    }
    this.data = new byte[length];
    this.offset = 0;
    this.cursor = 0;
  }

  public ByteBuffer(final byte[] data)
  {
    if (data == null)
    {
      throw new NullPointerException();
    }
    this.data = data;
    this.offset = 0;
    this.cursor = data.length;
  }

  public ByteBuffer(final byte[] data, final int offset, final int length)
  {
    if (length < 0)
    {
      throw new IndexOutOfBoundsException();
    }
    if (offset < 0)
    {
      throw new IndexOutOfBoundsException();
    }
    if (data == null)
    {
      throw new NullPointerException();
    }
    if ((length + offset) > data.length)
    {
      throw new IndexOutOfBoundsException();
    }
    this.data = data;
    this.offset = offset;
    this.cursor = offset + length;
  }

  public byte[] getData()
  {
    return data;
  }

  public void setData(final byte[] data, final int length, final int offset)
  {
    if (data == null)
    {
      throw new IllegalArgumentException();
    }
    if (length < 0)
    {
      throw new IndexOutOfBoundsException("Length < 0");
    }
    if (offset < 0)
    {
      throw new IllegalArgumentException("Offset < 0");
    }
    if (length + offset >= data.length)
    {
      throw new IllegalArgumentException("Length + Offset");
    }
    this.data = data;
    this.cursor = length + offset;
    this.offset = offset;
  }

  public int getLength()
  {
    return cursor - offset;
  }

  public int getOffset()
  {
    return offset;
  }

  public int getCursor()
  {
    return cursor;
  }

  public void ensureSize(final int length)
  {
    if (data.length < (offset + length))
    {
      final byte[] newdata = new byte[offset + length];
      System.arraycopy(data, 0, newdata, 0, data.length);
      data = newdata;
    }
  }

  public void setCursor(final int cursor)
  {
    if (cursor < offset)
    {
      throw new IndexOutOfBoundsException();
    }
    if (cursor > data.length)
    {
      throw new IndexOutOfBoundsException();
    }
    this.cursor = cursor;
  }
}