当前位置: 首页>>代码示例>>Java>>正文


Java BsonReader.getCurrentBsonType方法代码示例

本文整理汇总了Java中org.bson.BsonReader.getCurrentBsonType方法的典型用法代码示例。如果您正苦于以下问题:Java BsonReader.getCurrentBsonType方法的具体用法?Java BsonReader.getCurrentBsonType怎么用?Java BsonReader.getCurrentBsonType使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在org.bson.BsonReader的用法示例。


在下文中一共展示了BsonReader.getCurrentBsonType方法的8个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: handleArrayForBsonReader

import org.bson.BsonReader; //导入方法依赖的package包/类
private Object handleArrayForBsonReader(BsonReader bsonReader, Field field, BsonMapperConfig bsonMapperConfig) {
    Class<?> fieldType = field.getType();
    ArrayList<Object> arrayList = new ArrayList<Object>();
    bsonReader.readStartArray();
    while (bsonReader.readBsonType() != BsonType.END_OF_DOCUMENT) {
        BsonType currentBsonType = bsonReader.getCurrentBsonType();
        if (currentBsonType == BsonType.NULL) {
            continue;
        }
        if (currentBsonType == BsonType.ARRAY) {
            arrayList.add(decode(bsonReader, field, bsonMapperConfig));
        } else {
            Object javaValue;
            if (currentBsonType == BsonType.DOCUMENT) {
                javaValue = BsonValueConverterRepertory.getBsonDocumentConverter().decode(bsonReader, fieldType.getComponentType(), bsonMapperConfig);
            } else {
                javaValue = BsonValueConverterRepertory.getByteIOConverterByBsonType(currentBsonType).decode(bsonReader);
            }
            arrayList.add(javaValue);
        }
    }
    bsonReader.readEndArray();
    return arrayList.toArray((Object[]) Array.newInstance(fieldType.getComponentType(), 0));
}
 
开发者ID:welkinbai,项目名称:BsonMapper,代码行数:25,代码来源:BsonArrayConverter.java

示例2: decode

import org.bson.BsonReader; //导入方法依赖的package包/类
public void decode(BsonReader reader, T instance, DecoderContext decoderContext) {
    LOGGER.debug("Decode field : " + getMappedFieldName() + " Signature: " + fieldTypePair.getRealType());
    if (field.getType().isPrimitive()) {
        if (reader.getCurrentBsonType() == BsonType.NULL || reader.getCurrentBsonType() == BsonType.UNDEFINED) {
            reader.skipValue();
        } else {
            primitiveType.decode(reader, instance, decoderContext, this);
        }
    } else if (codec != null) {
        if (reader.getCurrentBsonType() == BsonType.NULL ) {
            reader.readNull();
            setFieldValue(instance, null);
        }
        else if (reader.getCurrentBsonType() == BsonType.UNDEFINED) {
            reader.skipValue();
        }
        else {
            F decoded = codec.decode(reader, decoderContext);
            setFieldValue(instance, decoded);
        }
    }
}
 
开发者ID:axelspringer,项目名称:polymorphia,代码行数:23,代码来源:MappedField.java

示例3: decode

import org.bson.BsonReader; //导入方法依赖的package包/类
@Override
default T decode(BsonReader reader, DecoderContext decoderContext) {
    T newInstance;
    if (reader.getCurrentBsonType() == null || reader.getCurrentBsonType() == BsonType.DOCUMENT) {
        reader.readStartDocument();
        newInstance = decodeFields(reader, decoderContext, newInstance());
        reader.readEndDocument();
        return newInstance;
    } else {
        LOGGER.error("Expected to read document but reader is in state {}. Skipping value!", reader.getCurrentBsonType());
        reader.skipValue();
        return null;
    }
}
 
开发者ID:axelspringer,项目名称:polymorphia,代码行数:15,代码来源:PolymorphicCodec.java

示例4: readValue

import org.bson.BsonReader; //导入方法依赖的package包/类
private Object readValue(final BsonReader reader, final DecoderContext decoderContext) {
    BsonType bsonType = reader.getCurrentBsonType();
    if (bsonType == BsonType.NULL) {
        reader.readNull();
        return null;
    } else if (bsonType == BsonType.ARRAY) {
        return readList(reader, decoderContext);
    } else if (bsonType == BsonType.BINARY && BsonBinarySubType.isUuid(reader.peekBinarySubType()) && reader.peekBinarySize() == 16) {
        return codecRegistry.get(UUID.class).decode(reader, decoderContext);
    }
    return bsonTypeCodecMap.get(bsonType).decode(reader, decoderContext);
}
 
开发者ID:axelspringer,项目名称:polymorphia,代码行数:13,代码来源:SpecialFieldsMapCodec.java

示例5: decode

import org.bson.BsonReader; //导入方法依赖的package包/类
/**
 * bsonReader中读取Bson到POJO/decode from bsonReader->POJO
 *
 * @param bsonReader
 * @param targetClazz
 * @param bsonMapperConfig
 * @param <T>
 * @return
 */
<T> T decode(BsonReader bsonReader, Class<T> targetClazz, BsonMapperConfig bsonMapperConfig) {
    MAPPER_LAYER_COUNTER.addCount(bsonMapperConfig);
    try {
        bsonReader.readStartDocument();
        Map<String, Field> bsonNameFieldInfoMap = getBsonNameFieldInfoMap(targetClazz);
        T target = Utils.newInstanceByClazz(targetClazz);
        while (bsonReader.readBsonType() != BsonType.END_OF_DOCUMENT) {
            String bsonName = bsonReader.readName();
            Field field = bsonNameFieldInfoMap.get(bsonName);
            if (field == null || bsonReader.getCurrentBsonType() == BsonType.NULL) {
                bsonReader.skipValue();
                continue;
            }
            Object javaValue;
            try {
                javaValue = getJavaValueByBinaryReader(bsonReader, field, bsonMapperConfig);
            } catch (BsonMapperConverterException e) {
                throw new BsonMapperConverterException("error when try to get java value from Bson.BsonName:" + bsonName, e);
            }
            setJavaValueToField(targetClazz, target, field, javaValue);
        }
        bsonReader.readEndDocument();
        return target;
    } finally {
        MAPPER_LAYER_COUNTER.reduceCount();
    }
}
 
开发者ID:welkinbai,项目名称:BsonMapper,代码行数:37,代码来源:BsonDocumentConverter.java

示例6: getJavaValueByBinaryReader

import org.bson.BsonReader; //导入方法依赖的package包/类
private Object getJavaValueByBinaryReader(BsonReader bsonReader, Field field, BsonMapperConfig bsonMapperConfig) {
    BsonType currentBsonType = bsonReader.getCurrentBsonType();
    if (currentBsonType == BsonType.DOCUMENT) {
        return decode(bsonReader, field.getType(), bsonMapperConfig);
    }
    if (currentBsonType == BsonType.ARRAY) {
        return BsonValueConverterRepertory.getBsonArrayConverter().decode(bsonReader, field, bsonMapperConfig);
    }
    if (currentBsonType == BsonType.OBJECT_ID) {
        ObjectId objectId = (ObjectId) BsonValueConverterRepertory.getByteIOConverterByBsonType(currentBsonType).decode(bsonReader);
        return getObjectIdByRealType(field.getType(), objectId);
    }
    return BsonValueConverterRepertory.getByteIOConverterByBsonType(currentBsonType).decode(bsonReader);
}
 
开发者ID:welkinbai,项目名称:BsonMapper,代码行数:15,代码来源:BsonDocumentConverter.java

示例7: handleCollectionForBsonReader

import org.bson.BsonReader; //导入方法依赖的package包/类
Object handleCollectionForBsonReader(BsonReader bsonReader, Field field, BsonMapperConfig bsonMapperConfig) {
    Class<?> fieldType = field.getType();
    Class<?> implClass = Utils.giveImplClassIfSupport(fieldType);
    if (Utils.isUnableAddCollectionClazz(implClass)) {
        return null;
    }
    BsonArrayField bsonArrayField = Utils.getBsonArrayFieldAnnotation(field);
    Class<?> targetComponentClazz = bsonArrayField.componentType();

    Object collectionObject = Utils.newInstanceByClazz(implClass);
    Method method;
    try {
        method = implClass.getMethod("add", Object.class);
    } catch (NoSuchMethodException e) {
        throw new BsonMapperConverterException("NoSuchMethodException", e);
    }

    bsonReader.readStartArray();
    while (bsonReader.readBsonType() != BsonType.END_OF_DOCUMENT) {
        BsonType currentBsonType = bsonReader.getCurrentBsonType();
        if (currentBsonType == BsonType.NULL) {
            continue;
        }
        if (currentBsonType == BsonType.ARRAY) {
            Utils.methodInvoke(method, collectionObject, decode(bsonReader, field, bsonMapperConfig));
        } else {
            Object javaValue;
            if (currentBsonType == BsonType.DOCUMENT) {
                javaValue = BsonValueConverterRepertory.getBsonDocumentConverter().decode(bsonReader, targetComponentClazz, bsonMapperConfig);
            } else {
                javaValue = BsonValueConverterRepertory.getByteIOConverterByBsonType(currentBsonType).decode(bsonReader);
            }
            Utils.methodInvoke(method, collectionObject, javaValue);
        }
    }
    bsonReader.readEndArray();
    return collectionObject;
}
 
开发者ID:welkinbai,项目名称:BsonMapper,代码行数:39,代码来源:BsonArrayConverter.java

示例8: decode

import org.bson.BsonReader; //导入方法依赖的package包/类
@Override
public T decode(BsonReader reader, DecoderContext decoderContext) {
    if (reader.getCurrentBsonType() == BsonType.NULL) {
        reader.readNull();
        return null;
    }

    String discriminator = null;
    reader.mark();
    reader.readStartDocument();
    PolymorphicCodec<T> codec = null;
    while (reader.readBsonType() != BsonType.END_OF_DOCUMENT) {
        String fieldName = reader.readName();
        if (allDiscriminatorKeys.contains(fieldName)) {
            discriminator = reader.readString();
            codec = getCodecForDiscriminator(discriminator);
            if (codec != null) {
                //now check that the codec found actually has the correct
                String discriminatorKeyForClass = discriminatorKeys.get(codec.getEncoderClass());
                if (fieldName.equals(discriminatorKeyForClass)) {
                    break;
                } else {
                    discriminator = null;
                    codec = null;
                    LOGGER.warn("Confusing. Skipping discriminator {} encoded in discriminator key {} since the " +
                                    "destination class is declaring a different discriminator key {}.",
                            discriminator, fieldName, discriminatorKeyForClass);
                }
            }
        } else {
            reader.skipValue();
        }
    }

    reader.reset();

    // try fallback and legacy handling
    if (codec == null) {
        if (discriminator != null) {
            LOGGER.warn("At least one valid discriminator {} was found in database, but no matching codec found at all.", discriminator);
            reader.skipValue();
            return null; // todo: when switching to mongo db 3.6 an exception should be thrown instead of returning null
        }
        LOGGER.debug("No discriminator found in db for entity. Trying fallback. Fallback is {}", fallBackCodec);
        codec = fallBackCodec;
        if (codec == null) {
            LOGGER.debug("FallbackCodec is null. Still no matching codec found for discriminator {} within discriminatorToCodec {}", discriminator, discriminatorToCodec);
            if (classToCodec.values().size() == 1) {
                codec = classToCodec.values().iterator().next();
                LOGGER.debug("Found single possible codec {} for type {}", codec, getEncoderClass());
            }
            else {
                LOGGER.warn("Legacy handling to resolve entities in db without discriminator failed as there are (now?) more than one codecs available {}. One option is to use @DiscriminatrFallback at the legacy class or to add discriminators to the entities within the database. For now, skipping value.", classToCodec);
                // TODO is skipping the right way to handle this? This might lead to lost data if a read object is rewritten to the database again...
                reader.skipValue();
                return null;// todo: when switching to mongo db 3.6 an exception should be thrown instead of returning null
            }
        }
    }


    return decodeWithType(reader, decoderContext, codec);
}
 
开发者ID:axelspringer,项目名称:polymorphia,代码行数:64,代码来源:PolymorphicReflectionCodec.java


注:本文中的org.bson.BsonReader.getCurrentBsonType方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。