All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.github.matteobertozzi.yajbe.YajbeFactory Maven / Gradle / Ivy

/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You 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 io.github.matteobertozzi.yajbe;

import java.io.InputStream;
import java.io.OutputStream;
import java.io.Reader;
import java.io.Writer;

import com.fasterxml.jackson.core.JsonFactory;
import com.fasterxml.jackson.core.JsonParser;
import com.fasterxml.jackson.core.io.IOContext;

import io.github.matteobertozzi.yajbe.YajbeEnumMapping.YajbeEnumMappingConfig;

/**
 * Factory used for constructing {@link YajbeParser} and {@link YajbeGenerator}
 * instances; both of which handle
 * YAJBE
 * encoded data.
 * 

* Extends {@link JsonFactory} mostly so that users can actually use it in place * of regular JSON factory instances. *

* Note on using non-byte-based sources/targets (char based, like * {@link java.io.Reader} and {@link java.io.Writer}): these can not be * used; attempt will throw exception. */ public class YajbeFactory extends JsonFactory { private static final long serialVersionUID = 1; // 2.6 /** the enum mapping configuration that will be passed to the YajbeGenerator */ private final YajbeEnumMappingConfig enumConfig; /** * Creates a new YajbeFactory without enum mapping */ public YajbeFactory() { super(); this.enumConfig = null; } /** * Creates a new YajbeFactory with the specified enum mapping config * @param enumConfig the enum-mapping configuration */ public YajbeFactory(final YajbeEnumMappingConfig enumConfig) { this.enumConfig = enumConfig; } @Override public String getFormatName() { return "YAJBE"; } @Override public boolean requiresPropertyOrdering() { return false; } @Override public boolean canHandleBinaryNatively() { return true; } @Override public boolean canUseCharArrays() { return false; } @Override protected YajbeParser _createParser(final InputStream in, final IOContext ctxt) { return new YajbeParser(ctxt, _parserFeatures, _objectCodec, YajbeReader.fromStream(in)); } @Override protected JsonParser _createParser(final Reader r, final IOContext ctxt) { throw new UnsupportedOperationException(); } @Override protected JsonParser _createParser(final char[] data, final int offset, final int len, final IOContext ctxt, final boolean recyclable) { throw new UnsupportedOperationException(); } @Override protected YajbeParser _createParser(final byte[] data, final int offset, final int len, final IOContext ctxt) { return new YajbeParser(ctxt, _parserFeatures, _objectCodec, YajbeReader.fromBytes(data, offset, len)); } @Override protected YajbeGenerator _createGenerator(final Writer out, final IOContext ctxt) { throw new UnsupportedOperationException(); } @Override protected YajbeGenerator _createUTF8Generator(final OutputStream out, final IOContext ctxt) { return new YajbeGenerator(ctxt, _generatorFeatures, _objectCodec, out, enumConfig); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy