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

com.landawn.abacus.parser.ParserConfig Maven / Gradle / Ivy

Go to download

A general programming library in Java/Android. It's easy to learn and simple to use with concise and powerful APIs.

There is a newer version: 5.3.16
Show newest version
/*
 * Copyright (C) 2015 HaiYang Li
 *
 * 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.landawn.abacus.parser;

import java.util.Collection;
import java.util.HashMap;
import java.util.Map;

import com.landawn.abacus.annotation.JsonXmlField;

/**
 *
 * @author Haiyang Li
 * @param 
 * @see JsonXmlField
 * @since 0.8
 */
public abstract class ParserConfig> implements Cloneable {

    Map, Collection> ignoredPropNames = null;

    /**
     * Gets the ignored prop names.
     *
     * @return
     */
    public Map, Collection> getIgnoredPropNames() {
        return ignoredPropNames;
    }

    /**
     * Gets the ignored prop names.
     *
     * @param cls
     * @return
     */
    public Collection getIgnoredPropNames(Class cls) {
        if (this.ignoredPropNames == null) {
            return null;
        }

        Collection result = this.ignoredPropNames.get(cls);

        if (result == null) {
            result = this.ignoredPropNames.get(Object.class);
        }

        return result;
    }

    /**
     * Sets the ignored prop names.
     *
     * @param ignoredPropNames
     * @return
     */
    public C setIgnoredPropNames(Collection ignoredPropNames) {
        return setIgnoredPropNames(Object.class, ignoredPropNames);
    }

    /**
     * Sets the ignored prop names.
     *
     * @param cls
     * @param ignoredPropNames
     * @return
     */
    public C setIgnoredPropNames(Class cls, Collection ignoredPropNames) {
        if (this.ignoredPropNames == null) {
            this.ignoredPropNames = new HashMap<>();
        }

        this.ignoredPropNames.put(cls, ignoredPropNames);

        return (C) this;
    }

    /**
     * Sets the ignored prop names.
     *
     * @param ignoredPropNames
     * @return
     */
    public C setIgnoredPropNames(Map, Collection> ignoredPropNames) {
        this.ignoredPropNames = ignoredPropNames;

        return (C) this;
    }

    public C copy() {
        try {
            return (C) super.clone();
        } catch (CloneNotSupportedException e) {
            throw new RuntimeException(e); // should never happen.
        }
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy