AmbiguousObjectException.java

  1. /*
  2.  * Copyright (C) 2010, Google Inc.
  3.  * and other copyright owners as documented in the project's IP log.
  4.  *
  5.  * This program and the accompanying materials are made available
  6.  * under the terms of the Eclipse Distribution License v1.0 which
  7.  * accompanies this distribution, is reproduced below, and is
  8.  * available at http://www.eclipse.org/org/documents/edl-v10.php
  9.  *
  10.  * All rights reserved.
  11.  *
  12.  * Redistribution and use in source and binary forms, with or
  13.  * without modification, are permitted provided that the following
  14.  * conditions are met:
  15.  *
  16.  * - Redistributions of source code must retain the above copyright
  17.  *   notice, this list of conditions and the following disclaimer.
  18.  *
  19.  * - Redistributions in binary form must reproduce the above
  20.  *   copyright notice, this list of conditions and the following
  21.  *   disclaimer in the documentation and/or other materials provided
  22.  *   with the distribution.
  23.  *
  24.  * - Neither the name of the Eclipse Foundation, Inc. nor the
  25.  *   names of its contributors may be used to endorse or promote
  26.  *   products derived from this software without specific prior
  27.  *   written permission.
  28.  *
  29.  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND
  30.  * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
  31.  * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  32.  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  33.  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
  34.  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  35.  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
  36.  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
  37.  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
  38.  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
  39.  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
  40.  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
  41.  * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  42.  */

  43. package org.eclipse.jgit.errors;

  44. import java.io.IOException;
  45. import java.text.MessageFormat;
  46. import java.util.Collection;

  47. import org.eclipse.jgit.internal.JGitText;
  48. import org.eclipse.jgit.lib.AbbreviatedObjectId;
  49. import org.eclipse.jgit.lib.ObjectId;

  50. /**
  51.  * An {@link org.eclipse.jgit.lib.AbbreviatedObjectId} cannot be extended.
  52.  */
  53. public class AmbiguousObjectException extends IOException {
  54.     private static final long serialVersionUID = 1L;

  55.     private final AbbreviatedObjectId missing;

  56.     private final Collection<ObjectId> candidates;

  57.     /**
  58.      * Construct a MissingObjectException for the specified object id. Expected
  59.      * type is reported to simplify tracking down the problem.
  60.      *
  61.      * @param id
  62.      *            SHA-1
  63.      * @param candidates
  64.      *            the candidate matches returned by the ObjectReader.
  65.      */
  66.     public AmbiguousObjectException(final AbbreviatedObjectId id,
  67.             final Collection<ObjectId> candidates) {
  68.         super(MessageFormat.format(JGitText.get().ambiguousObjectAbbreviation,
  69.                 id.name()));
  70.         this.missing = id;
  71.         this.candidates = candidates;
  72.     }

  73.     /**
  74.      * Get the {@code AbbreviatedObjectId} that has more than one result
  75.      *
  76.      * @return the {@code AbbreviatedObjectId} that has more than one result
  77.      */
  78.     public AbbreviatedObjectId getAbbreviatedObjectId() {
  79.         return missing;
  80.     }

  81.     /**
  82.      * Get the matching candidates (or at least a subset of them)
  83.      *
  84.      * @return the matching candidates (or at least a subset of them)
  85.      */
  86.     public Collection<ObjectId> getCandidates() {
  87.         return candidates;
  88.     }
  89. }