001 /*
002 * The MIT License
003 * Copyright (c) 2012 Microsoft Corporation
004 *
005 * Permission is hereby granted, free of charge, to any person obtaining a copy
006 * of this software and associated documentation files (the "Software"), to deal
007 * in the Software without restriction, including without limitation the rights
008 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
009 * copies of the Software, and to permit persons to whom the Software is
010 * furnished to do so, subject to the following conditions:
011 *
012 * The above copyright notice and this permission notice shall be included in
013 * all copies or substantial portions of the Software.
014 *
015 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
016 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
017 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
018 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
019 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
020 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
021 * THE SOFTWARE.
022 */
023
024 package microsoft.exchange.webservices.data.core.exception.service.local;
025
026 import microsoft.exchange.webservices.data.core.exception.service.local.ServiceLocalException;
027
028 /**
029 * Represents an error that occurs when an operation on a property fails.
030 */
031 public class PropertyException extends ServiceLocalException {
032
033 /**
034 * Constant serialized ID used for compatibility.
035 */
036 private static final long serialVersionUID = 1L;
037
038 /**
039 * The name.
040 */
041 private String name;
042
043 /**
044 * Instantiates a new property exception.
045 */
046 public PropertyException() {
047 super();
048 }
049
050 /**
051 * Instantiates a new property exception.
052 *
053 * @param name the name
054 */
055 public PropertyException(String name) {
056 super();
057 this.name = name;
058 }
059
060 /**
061 * Instantiates a new property exception.
062 *
063 * @param message the message
064 * @param name the name
065 */
066 public PropertyException(String message, String name) {
067 super(message);
068 this.name = name;
069 }
070
071 /**
072 * Instantiates a new property exception.
073 *
074 * @param message the message
075 * @param name the name
076 * @param innerException the inner exception
077 */
078 public PropertyException(String message, String name,
079 Exception innerException) {
080 super(message, innerException);
081 this.name = name;
082 }
083
084 /**
085 * Gets the name.
086 *
087 * @return the name
088 */
089 public String getName() {
090 return name;
091 }
092
093 }