projects
/
yaz4j-moved-to-github.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Rewrite exception handling
[yaz4j-moved-to-github.git]
/
src
/
main
/
java
/
org
/
yaz4j
/
Record.java
diff --git
a/src/main/java/org/yaz4j/Record.java
b/src/main/java/org/yaz4j/Record.java
index
b1a93ca
..
3770132
100644
(file)
--- a/
src/main/java/org/yaz4j/Record.java
+++ b/
src/main/java/org/yaz4j/Record.java
@@
-4,19
+4,22
@@
import org.yaz4j.jni.SWIGTYPE_p_ZOOM_record_p;
import org.yaz4j.jni.SWIGTYPE_p_int;
import org.yaz4j.jni.yaz4jlib;
import org.yaz4j.jni.SWIGTYPE_p_int;
import org.yaz4j.jni.yaz4jlib;
-public class Record {
-
- private SWIGTYPE_p_ZOOM_record_p record = null;
- private ResultSet resultSet = null;
+public class Record implements Cloneable {
+ private SWIGTYPE_p_ZOOM_record_p record;
+ private ResultSet rset;
private boolean disposed = false;
private boolean disposed = false;
- Record(SWIGTYPE_p_ZOOM_record_p record, ResultSet resultSet) {
- this.resultSet = resultSet;
+ Record(SWIGTYPE_p_ZOOM_record_p record, ResultSet rset) {
+ this.record = record;
+ this.rset = rset;
+ }
+
+ protected Record(SWIGTYPE_p_ZOOM_record_p record) {
this.record = record;
}
public void finalize() {
this.record = record;
}
public void finalize() {
- dispose();
+ _dispose();
}
public byte[] get(String type) {
}
public byte[] get(String type) {
@@
-40,9
+43,17
@@
public class Record {
return new String(get("database"));
}
return new String(get("database"));
}
- public void dispose() {
+ public Object clone() {
+ SWIGTYPE_p_ZOOM_record_p clone = yaz4jlib.ZOOM_record_clone(record);
+ return new Record(clone);
+ }
+
+ void _dispose() {
if (!disposed) {
if (!disposed) {
- resultSet = null;
+ //was cloned, need to dealloc?
+ if (rset == null)
+ yaz4jlib.ZOOM_record_destroy(record);
+ rset = null;
record = null;
disposed = true;
}
record = null;
disposed = true;
}