OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-dev/] [or1k-gcc/] [libjava/] [classpath/] [java/] [sql/] [Clob.java] - Blame information for rev 779

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 771 jeremybenn
/* Clob.java -- Access Character Large OBjects
2
   Copyright (C) 1999, 2000, 2002, 2006 Free Software Foundation, Inc.
3
 
4
This file is part of GNU Classpath.
5
 
6
GNU Classpath is free software; you can redistribute it and/or modify
7
it under the terms of the GNU General Public License as published by
8
the Free Software Foundation; either version 2, or (at your option)
9
any later version.
10
 
11
GNU Classpath is distributed in the hope that it will be useful, but
12
WITHOUT ANY WARRANTY; without even the implied warranty of
13
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14
General Public License for more details.
15
 
16
You should have received a copy of the GNU General Public License
17
along with GNU Classpath; see the file COPYING.  If not, write to the
18
Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
19
02110-1301 USA.
20
 
21
Linking this library statically or dynamically with other modules is
22
making a combined work based on this library.  Thus, the terms and
23
conditions of the GNU General Public License cover the whole
24
combination.
25
 
26
As a special exception, the copyright holders of this library give you
27
permission to link this library with independent modules to produce an
28
executable, regardless of the license terms of these independent
29
modules, and to copy and distribute the resulting executable under
30
terms of your choice, provided that you also meet, for each linked
31
independent module, the terms and conditions of the license of that
32
module.  An independent module is a module which is not derived from
33
or based on this library.  If you modify this library, you may extend
34
this exception to your version of the library, but you are not
35
obligated to do so.  If you do not wish to do so, delete this
36
exception statement from your version. */
37
 
38
 
39
package java.sql;
40
 
41
import java.io.InputStream;
42
import java.io.OutputStream;
43
import java.io.Reader;
44
import java.io.Writer;
45
 
46
/**
47
 * This interface contains methods for accessing a SQL CLOB (Character Large
48
 * OBject) type.
49
 *
50
 * @author Aaron M. Renn (arenn@urbanophile.com)
51
 */
52
public interface Clob
53
{
54
  /**
55
   * This method returns the number of characters in this <code>Clob</code>.
56
   *
57
   * @return The number of characters in this <code>Clob</code>.
58
   * @exception SQLException If an error occurs.
59
   * @since 1.2
60
   */
61
  long length() throws SQLException;
62
 
63
  /**
64
   * This method returns the specified portion of this <code>Clob</code> as a
65
   * <code>String</code>.
66
   *
67
   * @param start The index into this <code>Clob</code> (index values
68
   *              start at 1) to start returning characters from.
69
   * @param count The requested number of characters to return.
70
   * @return The requested <code>Clob</code> section, as a <code>String</code>.
71
   * @exception SQLException If an error occurs.
72
   * @since 1.2
73
   */
74
  String getSubString(long start, int count) throws SQLException;
75
 
76
  /**
77
   * This method returns a character stream that reads the contents of this
78
   * <code>Clob</code>.
79
   *
80
   * @return A character stream to read this <code>Clob</code>'s contents.
81
   * @exception SQLException If an error occurs.
82
   * @since 1.2
83
   */
84
  Reader getCharacterStream() throws SQLException;
85
 
86
  /**
87
   * This method returns a byte stream that reads the contents of this
88
   * <code>Clob</code> as a series of ASCII bytes.
89
   *
90
   * @return A stream to read this <code>Clob</code>'s contents.
91
   * @exception SQLException If an error occurs.
92
   * @since 1.2
93
   */
94
  InputStream getAsciiStream() throws SQLException;
95
 
96
  /**
97
   * This method returns the index into this <code>Clob</code> of the first
98
   * occurrence of the specified character pattern (supplied by the caller as a
99
   * <code>String</code>). The search begins at the specified index.
100
   *
101
   * @param pattern The character pattern to search for, passed as a
102
   *                <code>String</code>.
103
   * @param start The index into this <code>Clob</code> to start searching
104
   *              (indices start at 1).
105
   * @return The index at which the pattern was found (indices start at 1), or
106
   *         -1 if the pattern was not found.
107
   * @exception SQLException If an error occurs.
108
   * @since 1.2
109
   */
110
  long position(String pattern, long start) throws SQLException;
111
 
112
  /**
113
   * This method returns the index into this <code>Clob</code> of the first
114
   * occurrence of the specified character pattern (supplied by the caller as a
115
   * <code>Clob</code>). The search begins at the specified index.
116
   *
117
   * @param pattern The character pattern to search for, passed as a
118
   *                <code>Clob</code>.
119
   * @param start The index into this <code>Clob</code> to start searching
120
   *              (indices start at 1).
121
   * @return The index at which the pattern was found (indices start at 1), or
122
   *         -1 if the pattern was not found.
123
   * @exception SQLException If an error occurs.
124
   * @since 1.2
125
   */
126
  long position(Clob pattern, long start) throws SQLException;
127
 
128
  /**
129
   * Writes the specified string into this <code>Clob</code>, starting at the
130
   * specified index.
131
   *
132
   * @param start The index at which the writing starts.
133
   * @param value The string to write.
134
   * @return The number of characters written.
135
   * @exception SQLException If an error occurs.
136
   * @since 1.4
137
   */
138
  int setString(long start, String value) throws SQLException;
139
 
140
  /**
141
   * Writes the specified portion of a string into this <code>Clob</code>,
142
   * starting at the specified index.
143
   *
144
   * @param startWrite The index at which the writing starts.
145
   * @param value The string to write a portion of.
146
   * @param startRead The offset into the string where the portion to copy
147
   *                  starts.
148
   * @param count The number of characters to write.
149
   * @return The number of characters written.
150
   * @exception SQLException If an error occurs.
151
   * @since 1.4
152
   */
153
  int setString(long startWrite, String value, int startRead, int count)
154
      throws SQLException;
155
 
156
  /**
157
   * Returns an ASCII text stream that writes into this <code>Clob</code>,
158
   * starting at the specified index.
159
   *
160
   * @param start The index at which the writing starts.
161
   * @return An ASCII text stream to write into this <code>Clob</code>.
162
   * @exception SQLException If an error occurs.
163
   * @since 1.4
164
   */
165
  OutputStream setAsciiStream(long start) throws SQLException;
166
 
167
  /**
168
   * Returns a character stream that writes into this <code>Clob</code>,
169
   * starting at the specified index.
170
   *
171
   * @param start The index at which the writing starts.
172
   * @return A character stream to write into this <code>Clob</code>.
173
   * @exception SQLException If an error occurs.
174
   * @since 1.4
175
   */
176
  Writer setCharacterStream(long start) throws SQLException;
177
 
178
  /**
179
   * Truncates this <code>Clob</code> to be at most the specified number of
180
   * characters long.
181
   *
182
   * @param count The length this <code>Clob</code> is truncated to.
183
   * @exception SQLException If an error occurs.
184
   * @since 1.4
185
   */
186
  void truncate(long count) throws SQLException;
187
}

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.