Skip to content

Commit 32200bd

Browse files
author
mpv1989
committed
Add cursor initializer (only for intern use)
1 parent f7e747b commit 32200bd

File tree

5 files changed

+77
-6
lines changed

5 files changed

+77
-6
lines changed

src/main/java/com/arangodb/ArangoCursor.java

Lines changed: 9 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -51,10 +51,18 @@ protected ArangoCursor(final InternalArangoDatabase<?, ?, ?, ?> db, final Arango
5151
super();
5252
this.execute = execute;
5353
this.type = type;
54-
iterator = new ArangoCursorIterator<T>(this, execute, db, result);
54+
iterator = createIterator(this, db, execute, result);
5555
id = result.getId();
5656
}
5757

58+
protected ArangoCursorIterator<T> createIterator(
59+
final ArangoCursor<T> cursor,
60+
final InternalArangoDatabase<?, ?, ?, ?> db,
61+
final ArangoCursorExecute execute,
62+
final CursorEntity result) {
63+
return new ArangoCursorIterator<T>(cursor, execute, db, result);
64+
}
65+
5866
/**
5967
* @return id of temporary cursor created on the server
6068
*/

src/main/java/com/arangodb/ArangoDB.java

Lines changed: 10 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -58,6 +58,7 @@
5858
import com.arangodb.model.LogOptions;
5959
import com.arangodb.model.UserCreateOptions;
6060
import com.arangodb.model.UserUpdateOptions;
61+
import com.arangodb.util.ArangoCursorInitializer;
6162
import com.arangodb.util.ArangoDeserializer;
6263
import com.arangodb.util.ArangoSerialization;
6364
import com.arangodb.util.ArangoSerializer;
@@ -359,6 +360,8 @@ public synchronized ArangoDB build() {
359360

360361
}
361362

363+
private ArangoCursorInitializer cursorInitializer;
364+
362365
public ArangoDB(final VstCommunicationSync.Builder vstBuilder, final HttpCommunication.Builder httpBuilder,
363366
final ArangoSerialization util, final CollectionCache collectionCache, final Protocol protocol) {
364367
super(new ArangoExecutorSync(createProtocol(vstBuilder, httpBuilder, util, collectionCache, protocol), util,
@@ -367,7 +370,8 @@ public ArangoDB(final VstCommunicationSync.Builder vstBuilder, final HttpCommuni
367370
collectionCache.init(new DBAccess() {
368371
@Override
369372
public ArangoDatabase db(final String name) {
370-
return new ArangoDatabase(cp, util, executor.documentCache(), name);
373+
return new ArangoDatabase(cp, util, executor.documentCache(), name)
374+
.setCursorInitializer(cursorInitializer);
371375
}
372376
});
373377
}
@@ -421,7 +425,7 @@ public ArangoDatabase db() {
421425
* @return database handler
422426
*/
423427
public ArangoDatabase db(final String name) {
424-
return new ArangoDatabase(this, name);
428+
return new ArangoDatabase(this, name).setCursorInitializer(cursorInitializer);
425429
}
426430

427431
/**
@@ -662,4 +666,8 @@ public LogLevelEntity setLogLevel(final LogLevelEntity entity) throws ArangoDBEx
662666
return executor.execute(setLogLevelRequest(entity), LogLevelEntity.class);
663667
}
664668

669+
public ArangoDB _setCursorInitializer(final ArangoCursorInitializer cursorInitializer) {
670+
this.cursorInitializer = cursorInitializer;
671+
return this;
672+
}
665673
}

src/main/java/com/arangodb/ArangoDatabase.java

Lines changed: 12 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -54,6 +54,7 @@
5454
import com.arangodb.model.GraphCreateOptions;
5555
import com.arangodb.model.TransactionOptions;
5656
import com.arangodb.model.TraversalOptions;
57+
import com.arangodb.util.ArangoCursorInitializer;
5758
import com.arangodb.util.ArangoSerialization;
5859
import com.arangodb.velocypack.Type;
5960
import com.arangodb.velocystream.Request;
@@ -65,6 +66,8 @@
6566
*/
6667
public class ArangoDatabase extends InternalArangoDatabase<ArangoDB, ArangoExecutorSync, Response, ConnectionSync> {
6768

69+
private ArangoCursorInitializer cursorInitializer;
70+
6871
protected ArangoDatabase(final ArangoDB arangoDB, final String name) {
6972
super(arangoDB, arangoDB.executor(), arangoDB.util(), name);
7073
}
@@ -283,7 +286,7 @@ public <T> ArangoCursor<T> cursor(final String cursorId, final Class<T> type) th
283286
}
284287

285288
private <T> ArangoCursor<T> createCursor(final CursorEntity result, final Class<T> type) {
286-
return new ArangoCursor<T>(this, new ArangoCursorExecute() {
289+
final ArangoCursorExecute execute = new ArangoCursorExecute() {
287290
@Override
288291
public CursorEntity next(final String id) {
289292
return executor.execute(queryNextRequest(id), CursorEntity.class);
@@ -293,7 +296,9 @@ public CursorEntity next(final String id) {
293296
public void close(final String id) {
294297
executor.execute(queryCloseRequest(id), Void.class);
295298
}
296-
}, type, result);
299+
};
300+
return cursorInitializer != null ? cursorInitializer.createInstance(this, execute, type, result)
301+
: new ArangoCursor<T>(this, execute, type, result);
297302
}
298303

299304
/**
@@ -675,4 +680,9 @@ public void reloadRouting() throws ArangoDBException {
675680
executor.execute(reloadRoutingRequest(), Void.class);
676681
}
677682

683+
protected ArangoDatabase setCursorInitializer(final ArangoCursorInitializer cursorInitializer) {
684+
this.cursorInitializer = cursorInitializer;
685+
return this;
686+
}
687+
678688
}

src/main/java/com/arangodb/internal/ArangoCursorIterator.java

Lines changed: 6 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -25,6 +25,7 @@
2525

2626
import com.arangodb.ArangoCursor;
2727
import com.arangodb.entity.CursorEntity;
28+
import com.arangodb.velocypack.VPackSlice;
2829

2930
/**
3031
* @author Mark Vollmary
@@ -68,7 +69,11 @@ public T next() {
6869
if (!hasNext()) {
6970
throw new NoSuchElementException();
7071
}
71-
return db.util().deserialize(result.getResult().get(pos++), cursor.getType());
72+
return deserialize(result.getResult().get(pos++), cursor.getType());
73+
}
74+
75+
protected <R> R deserialize(final VPackSlice result, final Class<R> type) {
76+
return db.util().deserialize(result, type);
7277
}
7378

7479
@Override
Lines changed: 40 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,40 @@
1+
/*
2+
* DISCLAIMER
3+
*
4+
* Copyright 2017 ArangoDB GmbH, Cologne, Germany
5+
*
6+
* Licensed under the Apache License, Version 2.0 (the "License");
7+
* you may not use this file except in compliance with the License.
8+
* You may obtain a copy of the License at
9+
*
10+
* http://www.apache.org/licenses/LICENSE-2.0
11+
*
12+
* Unless required by applicable law or agreed to in writing, software
13+
* distributed under the License is distributed on an "AS IS" BASIS,
14+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15+
* See the License for the specific language governing permissions and
16+
* limitations under the License.
17+
*
18+
* Copyright holder is ArangoDB GmbH, Cologne, Germany
19+
*/
20+
21+
package com.arangodb.util;
22+
23+
import com.arangodb.ArangoCursor;
24+
import com.arangodb.entity.CursorEntity;
25+
import com.arangodb.internal.ArangoCursorExecute;
26+
import com.arangodb.internal.InternalArangoDatabase;
27+
28+
/**
29+
* @author Mark Vollmary
30+
*
31+
*/
32+
public interface ArangoCursorInitializer {
33+
34+
<T> ArangoCursor<T> createInstance(
35+
final InternalArangoDatabase<?, ?, ?, ?> db,
36+
final ArangoCursorExecute execute,
37+
final Class<T> type,
38+
final CursorEntity result);
39+
40+
}

0 commit comments

Comments
 (0)