View Javadoc

1   /*
2    *   Copyright (C) Christian Schulte, 2005-206
3    *   All rights reserved.
4    *
5    *   Redistribution and use in source and binary forms, with or without
6    *   modification, are permitted provided that the following conditions
7    *   are met:
8    *
9    *     o Redistributions of source code must retain the above copyright
10   *       notice, this list of conditions and the following disclaimer.
11   *
12   *     o Redistributions in binary form must reproduce the above copyright
13   *       notice, this list of conditions and the following disclaimer in
14   *       the documentation and/or other materials provided with the
15   *       distribution.
16   *
17   *   THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
18   *   INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
19   *   AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
20   *   THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY DIRECT, INDIRECT,
21   *   INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22   *   NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23   *   DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24   *   THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25   *   (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26   *   THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27   *
28   *   $JOMC: NameType.java 4613 2012-09-22 10:07:08Z schulte $
29   *
30   */
31  package org.jomc.ant.types;
32  
33  import org.apache.commons.lang.builder.ToStringBuilder;
34  
35  /**
36   * Datatype holding a {@code name} property.
37   *
38   * @author <a href="mailto:cs@schulte.it">Christian Schulte</a>
39   * @version $JOMC: NameType.java 4613 2012-09-22 10:07:08Z schulte $
40   */
41  public class NameType implements Cloneable
42  {
43  
44      /** The name of the datatype. */
45      private String name;
46  
47      /** Creates a new {@code NameType} instance. */
48      public NameType()
49      {
50          super();
51      }
52  
53      /**
54       * Gets the value of the {@code name} property.
55       *
56       * @return The value of the {@code name} property.
57       *
58       * @see #setName(java.lang.String)
59       */
60      public final String getName()
61      {
62          return this.name;
63      }
64  
65      /**
66       * Sets the value of the {@code name} property.
67       *
68       * @param value The new value of the {@code name} property.
69       *
70       * @see #getName()
71       */
72      public final void setName( final String value )
73      {
74          this.name = value;
75      }
76  
77      /**
78       * Creates and returns a copy of this object.
79       *
80       * @return A copy of this object.
81       */
82      @Override
83      public NameType clone()
84      {
85          try
86          {
87              return (NameType) super.clone();
88          }
89          catch ( final CloneNotSupportedException e )
90          {
91              throw new AssertionError( e );
92          }
93      }
94  
95      /**
96       * Creates and returns a string representation of the object.
97       *
98       * @return A string representation of the object.
99       */
100     @Override
101     public String toString()
102     {
103         return ToStringBuilder.reflectionToString( this );
104     }
105 
106 }