/* * Copyright (c) 2014, Francis Galiegue (fgaliegue@gmail.com) * * This software is dual-licensed under: * * - the Lesser General Public License (LGPL) version 3.0 or, at your option, any * later version; * - the Apache Software License (ASL) version 2.0. * * The text of both licenses is available under the src/resources/ directory of * this project (under the names LGPL-3.0.txt and ASL-2.0.txt respectively). * * Direct link to the sources: * * - LGPL 3.0: https://www.gnu.org/licenses/lgpl-3.0.txt * - ASL 2.0: http://www.apache.org/licenses/LICENSE-2.0.txt */ package com.github.fge.avro.translators; import com.github.fge.jackson.NodeType; import com.google.common.collect.ImmutableMap; import org.apache.avro.Schema; import java.util.Map; public final class AvroTranslators { private static final Map<Schema.Type, AvroTranslator> TRANSLATORS; private AvroTranslators() { } static { final ImmutableMap.Builder<Schema.Type, AvroTranslator> builder = ImmutableMap.builder(); Schema.Type avroType; AvroTranslator translator; avroType = Schema.Type.NULL; translator = new SimpleTypeTranslator(NodeType.NULL); builder.put(avroType, translator); avroType = Schema.Type.BOOLEAN; translator = new SimpleTypeTranslator(NodeType.BOOLEAN); builder.put(avroType, translator); avroType = Schema.Type.STRING; translator = new SimpleTypeTranslator(NodeType.STRING); builder.put(avroType, translator); // Reuse for "bytes" avroType = Schema.Type.BYTES; translator = ByteTranslator.getInstance(); builder.put(avroType, translator); avroType = Schema.Type.INT; translator = IntTranslator.getInstance(); builder.put(avroType, translator); avroType = Schema.Type.LONG; translator = LongTranslator.getInstance(); builder.put(avroType, translator); avroType = Schema.Type.FLOAT; translator = new SimpleTypeTranslator(NodeType.NUMBER); builder.put(avroType, translator); // Reuse for "double" avroType = Schema.Type.DOUBLE; builder.put(avroType, translator); avroType = Schema.Type.MAP; translator = MapTranslator.getInstance(); builder.put(avroType, translator); avroType = Schema.Type.FIXED; translator = FixedTranslator.getInstance(); builder.put(avroType, translator); avroType = Schema.Type.ENUM; translator = EnumTranslator.getInstance(); builder.put(avroType, translator); avroType = Schema.Type.ARRAY; translator = ArrayTranslator.getInstance(); builder.put(avroType, translator); avroType = Schema.Type.UNION; translator = UnionTranslator.getInstance(); builder.put(avroType, translator); avroType = Schema.Type.RECORD; translator = RecordTranslator.getInstance(); builder.put(avroType, translator); TRANSLATORS = builder.build(); } public static AvroTranslator getTranslator(final Schema.Type avroType) { return TRANSLATORS.get(avroType); } }