/* * Copyright 2006 Amazon Technologies, Inc. or its affiliates. * Amazon, Amazon.com and Carbonado are trademarks or registered trademarks * of Amazon Technologies, Inc. or its affiliates. All rights reserved. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.amazon.carbonado.adapter; import java.lang.annotation.Documented; import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target; /** * Adapter that converts 'T' or 'F' to and from a boolean value. * *

Example:

 * public interface UserInfo extends Storable {
 *     @TrueFalseAdapter
 *     boolean isAdministrator();
 *     void setAdministrator(boolean admin);
 *
 *     ...
 * }
 * 
* * @author Brian S O'Neill * @see YesNoAdapter * @see AdapterDefinition */ @Documented @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.METHOD) @AdapterDefinition(storageTypePreferences={ char.class, Character.class, String.class }) public @interface TrueFalseAdapter { /** * Specify that this adapter should be lenient when converting characters * into booleans. By default it is true, and it accepts the following as * true: 'T', 't', 'Y', 'y', '1'. For false: 'F', 'f', 'N', 'n', '0'. When * lenient is false, only 'T' and 'F' are accepted. */ boolean lenient() default true; /** * Adapter implementation for {@link TrueFalseAdapter}. */ public static class Adapter { private final String mPropertyName; private final boolean mLenient; /** * @param type type of object that contains the adapted property * @param propertyName name of property with adapter * @param ann specific annotation that binds to this adapter class */ public Adapter(Class type, String propertyName, TrueFalseAdapter ann) { this(type, propertyName, ann == null ? true : ann.lenient()); } /** * @param type type of object that contains the adapted property * @param propertyName name of property with * @param lenient lenient when true */ public Adapter(Class type, String propertyName, boolean lenient) { mPropertyName = propertyName; mLenient = lenient; } /** * Adapts a boolean true or false into 'T' or 'F'. */ public char adaptToChar(boolean value) { return value ? 'T' : 'F'; } /** * Adapts a boolean true into 'T', and anything else to 'F'. */ public char adaptToChar(Boolean value) { return (value != null && value) ? 'T' : 'F'; } /** * Adapts a boolean true or false into 'T' or 'F'. */ public Character adaptToCharacter(boolean value) { return value ? 'T' : 'F'; } /** * Adapts a boolean true into 'T', and anything else to 'F'. */ public Character adaptToCharacter(Boolean value) { return (value != null && value) ? 'T' : 'F'; } /** * Adapts a boolean true or false into "T" or "F". */ public String adaptToString(boolean value) { return value ? "T" : "F"; } /** * Adapts a boolean true into "T", and anything else to "F". */ public String adaptToString(Boolean value) { return (value != null && value) ? "T" : "F"; } /** * Adapts a character 'T' or 'F' to true or false. If {@link * TrueFalseAdapter#lenient lenient}, other characters are accepted as * well. */ public boolean adaptToBoolean(char value) { switch (value) { case 'T': return true; case 'F': return false; case 't': case 'Y': case 'y': case '1': if (mLenient) { return true; } break; case 'f': case 'N': case 'n': case '0': if (mLenient) { return false; } break; } throw new IllegalArgumentException ("Cannot adapt '" + value + "' into boolean for property \"" + mPropertyName + '"'); } /** * Adapts a character 'T' or 'F' to true or false. If {@link * TrueFalseAdapter#lenient lenient}, other characters are accepted as * well. */ public boolean adaptToBoolean(Character value) { if (value == null) { if (mLenient) { return false; } } else { return adaptToBoolean(value.charValue()); } throw new IllegalArgumentException ("Cannot adapt '" + value + "' into boolean for property \"" + mPropertyName + '"'); } /** * Adapts a character "T" or "F" to true or false. If {@link * TrueFalseAdapter#lenient leneint}, other characters are accepted as * well. */ public boolean adaptToBoolean(String value) { int length; if (value == null || (length = value.length()) == 0) { if (mLenient) { return false; } } else if (length == 1 || mLenient) { return adaptToBoolean(value.charAt(0)); } throw new IllegalArgumentException ("Cannot adapt '" + value + "' into boolean for property \"" + mPropertyName + '"'); } /** * Adapts a character 'T' or 'F' to true or false. If {@link * TrueFalseAdapter#lenient lenient}, other characters are accepted as * well. */ public Boolean adaptToBooleanObj(char value) { return adaptToBoolean(value); } /** * Adapts a character 'T' or 'F' to true or false. If {@link * TrueFalseAdapter#lenient lenient}, other characters are accepted as * well. */ public Boolean adaptToBooleanObj(Character value) { return adaptToBoolean(value); } /** * Adapts a character "T" or "F" to true or false. If {@link * TrueFalseAdapter#lenient lenient}, other characters are accepted as * well. */ public Boolean adaptToBooleanObj(String value) { return adaptToBoolean(value); } } }