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 }