001 /* 002 * Jpkg - Java library and tools for operating system package creation. 003 * 004 * Copyright (c) 2007 Three Rings Design, Inc. 005 * All rights reserved. 006 * 007 * Redistribution and use in source and binary forms, with or without 008 * modification, are permitted provided that the following conditions 009 * are met: 010 * 1. Redistributions of source code must retain the above copyright 011 * notice, this list of conditions and the following disclaimer. 012 * 2. Redistributions in binary form must reproduce the above copyright 013 * notice, this list of conditions and the following disclaimer in the 014 * documentation and/or other materials provided with the distribution. 015 * 3. Neither the name of the copyright owner nor the names of contributors 016 * may be used to endorse or promote products derived from this software 017 * without specific prior written permission. 018 * 019 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 020 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 021 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 022 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE 023 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 024 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 025 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 026 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 027 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 028 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 029 * POSSIBILITY OF SUCH DAMAGE. 030 */ 031 package com.threerings.antidote; 032 033 import org.apache.tools.ant.Location; 034 035 /** 036 * Holds validation violation information, suitable for displaying user feedback. 037 * @see RequiresValidation 038 */ 039 public class Violation 040 { 041 /** 042 * Construct a new Violation, with the supplied {@link String} being a user readable reason 043 * that the validation occurred. 044 * @param reason The violation reason, as a user readable string. 045 * @param location The {@link Location} where the violation occurred. 046 */ 047 public Violation (String reason, Location location) 048 { 049 _reason = reason; 050 _location = location; 051 } 052 053 /** 054 * Returns the user readable reason for this violation. 055 */ 056 public String getReason () 057 { 058 return _reason; 059 } 060 061 /** 062 * Returns the location of this violation. 063 */ 064 public Location getLocation () 065 { 066 return _location; 067 } 068 069 @Override // from Object 070 public String toString () 071 { 072 return getLocation() + getReason(); 073 } 074 075 private final String _reason; 076 private final Location _location; 077 }