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

com.hp.autonomy.aci.content.fieldtext.FieldTextWrapper Maven / Gradle / Ivy

/*
 * Copyright 2009-2015 Hewlett-Packard Development Company, L.P.
 * Licensed under the MIT License (the "License"); you may not use this file except in compliance with the License.
 */

package com.hp.autonomy.aci.content.fieldtext;

import org.apache.commons.lang.Validate;

/**
 * The {@code FieldTextWrapper} class makes an immutable copy of another {@code FieldText} object. Though the classes
 * representing specifiers in this package are already immutable, {@code FieldTextBuilder} is not and in general
 * {@code FieldText} implementations are not obliged to be immutable. A {@code FieldTextWrapper} instance is not backed
 * by the original object, a copy of its size and string representation are taken.
 *
 * Objects that are not {@code FieldText} instances can also be wrapped, assuming that their {@code toString()} methods
 * return a fieldtext expression.
 */
public final class FieldTextWrapper extends AbstractFieldText {
    private final int size;
    private final String fieldText;

    /**
     * Creates an immutable copy of the specified {@code FieldText} object. The copy is not backed by the original
     * object.
     *
     * @param fieldText The object to copy. Must be non-null.
     */
    public FieldTextWrapper(final FieldText fieldText) {
        Validate.notNull(fieldText, "FieldText must not be null");

        this.fieldText = fieldText.toString();
        this.size = fieldText.size();

        Validate.notNull(this.fieldText, "FieldText string must not be null");
        Validate.isTrue(size >= 0, "FieldText size must be non-negative");
    }

    /**
     * Though primarily intended for converting a {@code String} representation of fieldtext into genuine a
     * {@code FieldText} object, any object may be used with a suitable {@code toString()} implementation. A suitable
     * size will be assigned though it may not accurately reflect the actual size of the fieldtext expression.
     *
     * @param fieldText The object to wrap. Must be non-null.
     */
    public FieldTextWrapper(final Object fieldText) {
        Validate.notNull(fieldText, "FieldText must not be null");

        this.fieldText = fieldText.toString().trim();

        if (this.fieldText.isEmpty()) {
            this.size = 0;
        }
        else {
            this.size = 2;
        }
    }

    /**
     * Though primarily intended for converting a {@code String} representation of fieldtext into genuine a
     * {@code FieldText} object, any object may be used with a suitable {@code toString()} implementation.
     *
     * @param fieldText The object to wrap. Must be non-null.
     * @param size The size of the {@code FieldTextWrapper}. Must be non-negative.
     */
    public FieldTextWrapper(final Object fieldText, final int size) {
        Validate.notNull(fieldText, "FieldText must not be null");
        Validate.isTrue(size >= 0, "FieldText size must not be negative");

        this.fieldText = fieldText.toString().trim();
        this.size = size;

        Validate.notNull(this.fieldText, "FieldText must not be null");
    }

    @Override
    public int size() {
        return size;
    }

    @Override
    public String toString() {
        return fieldText;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy