當前位置: 首頁>>代碼示例>>Java>>正文


Java BytesReference.hasArray方法代碼示例

本文整理匯總了Java中org.elasticsearch.common.bytes.BytesReference.hasArray方法的典型用法代碼示例。如果您正苦於以下問題:Java BytesReference.hasArray方法的具體用法?Java BytesReference.hasArray怎麽用?Java BytesReference.hasArray使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.elasticsearch.common.bytes.BytesReference的用法示例。


在下文中一共展示了BytesReference.hasArray方法的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: convertToJson

import org.elasticsearch.common.bytes.BytesReference; //導入方法依賴的package包/類
public static String convertToJson(BytesReference bytes, boolean reformatJson, boolean prettyPrint) throws IOException {
    if (bytes.hasArray()) {
        return convertToJson(bytes.array(), bytes.arrayOffset(), bytes.length(), reformatJson, prettyPrint);
    }
    XContentType xContentType = XContentFactory.xContentType(bytes);
    if (xContentType == XContentType.JSON && !reformatJson) {
        BytesArray bytesArray = bytes.toBytesArray();
        return new String(bytesArray.array(), bytesArray.arrayOffset(), bytesArray.length(), Charsets.UTF_8);
    }
    try (XContentParser parser = XContentFactory.xContent(xContentType).createParser(bytes.streamInput())) {
        parser.nextToken();
        XContentBuilder builder = XContentFactory.jsonBuilder();
        if (prettyPrint) {
            builder.prettyPrint();
        }
        builder.copyCurrentStructure(parser);
        return builder.string();
    }
}
 
開發者ID:baidu,項目名稱:Elasticsearch,代碼行數:20,代碼來源:XContentHelper.java

示例2: createParser

import org.elasticsearch.common.bytes.BytesReference; //導入方法依賴的package包/類
@Override
public XContentParser createParser(BytesReference bytes) throws IOException {
    if (bytes.hasArray()) {
        return createParser(bytes.array(), bytes.arrayOffset(), bytes.length());
    }
    return createParser(bytes.streamInput());
}
 
開發者ID:baidu,項目名稱:Elasticsearch,代碼行數:8,代碼來源:YamlXContent.java

示例3: copyRawValue

import org.elasticsearch.common.bytes.BytesReference; //導入方法依賴的package包/類
protected void copyRawValue(BytesReference content, XContent xContent) throws IOException {
    XContentParser parser = null;
    try {
        if (content.hasArray()) {
            parser = xContent.createParser(content.array(), content.arrayOffset(), content.length());
        } else {
            parser = xContent.createParser(content.streamInput());
        }
        copyCurrentStructure(parser);
    } finally {
        if (parser != null) {
            parser.close();
        }
    }
}
 
開發者ID:baidu,項目名稱:Elasticsearch,代碼行數:16,代碼來源:JsonXContentGenerator.java

示例4: field

import org.elasticsearch.common.bytes.BytesReference; //導入方法依賴的package包/類
/**
 * Writes the binary content of the given BytesReference
 * Use {@link org.elasticsearch.common.xcontent.XContentParser#binaryValue()} to read the value back
 */
public XContentBuilder field(String name, BytesReference value) throws IOException {
    field(name);
    if (!value.hasArray()) {
        value = value.toBytesArray();
    }
    generator.writeBinary(value.array(), value.arrayOffset(), value.length());
    return this;
}
 
開發者ID:baidu,項目名稱:Elasticsearch,代碼行數:13,代碼來源:XContentBuilder.java

示例5: messageReceived

import org.elasticsearch.common.bytes.BytesReference; //導入方法依賴的package包/類
@Override
public void messageReceived(BlobRecoveryChunkRequest request, TransportChannel channel) throws Exception {

    BlobRecoveryStatus onGoingRecovery = onGoingRecoveries.get(request.recoveryId());
    if (onGoingRecovery == null) {
         // shard is getting closed on us
        throw new IllegalBlobRecoveryStateException("Could not retrieve onGoingRecoveryStatus");
    }

    BlobRecoveryTransferStatus transferStatus = onGoingRecovery.onGoingTransfers().get(request.transferId());
    BlobShard shard = onGoingRecovery.blobShard;
    if (onGoingRecovery.canceled()) {
        onGoingRecovery.sentCanceledToSource();
         throw new IndexShardClosedException(onGoingRecovery.shardId());
    }

    if (transferStatus == null) {
        throw new IndexShardClosedException(onGoingRecovery.shardId());
    }

    BytesReference content = request.content();
    if (!content.hasArray()) {
        content = content.toBytesArray();
    }
    transferStatus.outputStream().write(
        content.array(), content.arrayOffset(), content.length()
    );

    if (request.isLast()) {
        transferStatus.outputStream().close();
        File source = new File(shard.blobContainer().getBaseDirectory(),
            transferStatus.sourcePath()
        );
        File target = new File(shard.blobContainer().getBaseDirectory(),
            transferStatus.targetPath()
        );

        if (target.exists()) {
            logger.info("target file {} exists already.", target.getName());
            // this might happen on bad timing while recovering/relocating.
            // noop
        } else {
            if (!source.renameTo(target)) {
                throw new BlobWriteException(target.getName(), target.length(), null);
            }
        }

        onGoingRecovery.onGoingTransfers().remove(request.transferId());
    }

    channel.sendResponse(TransportResponse.Empty.INSTANCE);
}
 
開發者ID:baidu,項目名稱:Elasticsearch,代碼行數:53,代碼來源:BlobRecoveryTarget.java

示例6: wrap

import org.elasticsearch.common.bytes.BytesReference; //導入方法依賴的package包/類
public static StreamInput wrap(BytesReference reference) {
    if (reference.hasArray() == false) {
        reference = reference.toBytesArray();
    }
    return wrap(reference.array(), reference.arrayOffset(), reference.length());
}
 
開發者ID:baidu,項目名稱:Elasticsearch,代碼行數:7,代碼來源:StreamInput.java


注:本文中的org.elasticsearch.common.bytes.BytesReference.hasArray方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。