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

org.fusesource.hawtbuf.proto.UninitializedMessageException Maven / Gradle / Ivy

// Protocol Buffers - Google's data interchange format
// Copyright 2008 Google Inc.
// http://code.google.com/p/protobuf/
//
// 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 org.fusesource.hawtbuf.proto;

import java.util.Collections;
import java.util.List;

/**
 * Thrown when attempting to build a protocol message that is missing required
 * fields. This is a {@code RuntimeException} because it normally represents a
 * programming error: it happens when some code which constructs a message fails
 * to set all the fields. {@code parseFrom()} methods do not throw this;
 * they throw an {@link InvalidProtocolBufferException} if required fields are
 * missing, because it is not a programming error to receive an incomplete
 * message. In other words, {@code UninitializedMessageException} should never
 * be thrown by correct code, but {@code InvalidProtocolBufferException} might
 * be.
 * 
 * @author [email protected] Kenton Varda
 */
public class UninitializedMessageException extends RuntimeException {

    public UninitializedMessageException(List missingFields) {
        super(buildDescription(missingFields));
        this.missingFields = missingFields;
    }

    private final List missingFields;

    /**
     * Get a list of human-readable names of required fields missing from this
     * message. Each name is a full path to a field, e.g. "foo.bar[5].baz".
     */
    public List getMissingFields() {
        return Collections.unmodifiableList(missingFields);
    }

    /**
     * Converts this exception to an {@link InvalidProtocolBufferException}.
     * When a parsed message is missing required fields, this should be thrown
     * instead of {@code UninitializedMessageException}.
     */
    public InvalidProtocolBufferException asInvalidProtocolBufferException() {
        return new InvalidProtocolBufferException(getMessage());
    }

    /** Construct the description string for this exception. */
    private static String buildDescription(List missingFields) {
        StringBuilder description = new StringBuilder("Message missing required fields: ");
        boolean first = true;
        for (String field : missingFields) {
            if (first) {
                first = false;
            } else {
                description.append(", ");
            }
            description.append(field);
        }
        return description.toString();
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy