com.mongodb.async.client.MappingAsyncBatchCursor Maven / Gradle / Ivy
/*
* Copyright 2015 MongoDB, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.mongodb.async.client;
import com.mongodb.Function;
import com.mongodb.async.AsyncBatchCursor;
import com.mongodb.async.SingleResultCallback;
import java.util.ArrayList;
import java.util.List;
class MappingAsyncBatchCursor implements AsyncBatchCursor {
private final AsyncBatchCursor batchCursor;
private final Function mapper;
MappingAsyncBatchCursor(final AsyncBatchCursor batchCursor, final Function mapper) {
this.batchCursor = batchCursor;
this.mapper = mapper;
}
@Override
public void next(final SingleResultCallback> callback) {
batchCursor.next(new SingleResultCallback>() {
@Override
public void onResult(final List results, final Throwable t) {
if (t != null) {
callback.onResult(null, t);
} else if (results != null) {
try {
List mappedResults = new ArrayList();
for (T result : results) {
mappedResults.add(mapper.apply(result));
}
callback.onResult(mappedResults, null);
} catch (Throwable t1) {
callback.onResult(null, t1);
}
} else {
callback.onResult(null, null);
}
}
});
}
@Override
public void setBatchSize(final int batchSize) {
batchCursor.setBatchSize(batchSize);
}
@Override
public int getBatchSize() {
return batchCursor.getBatchSize();
}
@Override
public boolean isClosed() {
return batchCursor.isClosed();
}
@Override
public void close() {
batchCursor.close();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy