View Javadoc
1   /*
2    * (c) Copyright 2006-2020 by rapiddweller GmbH & Volker Bergmann. All rights reserved.
3    *
4    * Redistribution and use in source and binary forms, with or without
5    * modification, is permitted under the terms of the
6    * GNU General Public License.
7    *
8    * For redistributing this software or a derivative work under a license other
9    * than the GPL-compatible Free Software License as defined by the Free
10   * Software Foundation or approved by OSI, you must first obtain a commercial
11   * license to this software product from rapiddweller GmbH & Volker Bergmann.
12   *
13   * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
14   * WITHOUT A WARRANTY OF ANY KIND. ALL EXPRESS OR IMPLIED CONDITIONS,
15   * REPRESENTATIONS AND WARRANTIES, INCLUDING ANY IMPLIED WARRANTY OF
16   * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT, ARE
17   * HEREBY EXCLUDED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
18   * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
19   * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
20   * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
21   * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
22   * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
23   * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
24   * POSSIBILITY OF SUCH DAMAGE.
25   */
26  
27  package com.rapiddweller.domain.person;
28  
29  import com.rapiddweller.common.ConversionException;
30  import com.rapiddweller.common.converter.ThreadSafeConverter;
31  
32  /**
33   * Converts a {@link Gender} enumeration value to a configurable String.<br/>
34   * <br/>
35   * Created at 11.03.2009 12:31:43
36   *
37   * @author Volker Bergmann
38   * @since 0.5.8
39   */
40  public class GenderConverter extends ThreadSafeConverter<Gender, String> {
41  
42    private String male;
43    private String female;
44  
45    /**
46     * Instantiates a new Gender converter.
47     */
48    public GenderConverter() {
49      this("m", "f");
50    }
51  
52    /**
53     * Instantiates a new Gender converter.
54     *
55     * @param male   the male
56     * @param female the female
57     */
58    public GenderConverter(String male, String female) {
59      super(Gender.class, String.class);
60      this.male = male;
61      this.female = female;
62    }
63  
64    /**
65     * Sets male.
66     *
67     * @param male the male
68     */
69    public void setMale(String male) {
70      this.male = male;
71    }
72  
73    /**
74     * Sets female.
75     *
76     * @param female the female
77     */
78    public void setFemale(String female) {
79      this.female = female;
80    }
81  
82    @Override
83    public String convert(Gender gender) throws ConversionException {
84      return (gender != null ? (Gender.MALE.equals(gender) ? male : female) :
85          null);
86    }
87  
88  }