All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.commons.jexl.util.BooleanPropertyExecutor Maven / Gradle / Ivy

Go to download

Jexl is an implementation of the JSTL Expression Language with extensions.

There is a newer version: 1.1-hudson-20090508
Show newest version
/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You 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 org.apache.commons.jexl.util;

import org.apache.commons.logging.Log;
/**
 *  Handles discovery and valuation of a
 *  boolean object property, of the
 *  form public boolean is<Property> when executed.
 *
 *  We do this separately as to preserve the current
 *  quasi-broken semantics of get <as is property>
 *  get<flip 1st char> get("property") and now followed
 *  by is<Property>.
 *
 *  @since 1.0
 *  @author Geir Magnusson Jr.
 *  @version $Id: BooleanPropertyExecutor.java 584046 2007-10-12 05:14:37Z proyal $
 */
public class BooleanPropertyExecutor extends PropertyExecutor {

    /**
     * Constructor.
     *
     * @param rlog The instance log.
     * @param is The JEXL introspector.
     * @param clazz The class being analyzed.
     * @param property The boolean property.
     */
    public BooleanPropertyExecutor(Log rlog,
        org.apache.commons.jexl.util.introspection.Introspector is,
        Class clazz, String property) {
            super(rlog, is, clazz, property);
    }

    /**
     * Locate the getter method for this boolean property.
     *
     * @param clazz The class being analyzed.
     * @param property Name of boolean property.
     */
    protected void discover(Class clazz, String property) {
        try {
            char c;
            StringBuffer sb;

            Object[] params = {};

            /*
             *  now look for a boolean isFoo
             */

            sb = new StringBuffer("is");
            sb.append(property);

            methodUsed = sb.toString();
            method = introspector.getMethod(clazz, methodUsed, params);

            if (null == method)
            {
                c = sb.charAt(2);

                if (Character.isLowerCase(c)) {
                    sb.setCharAt(2, Character.toUpperCase(c));
                } else {
                    sb.setCharAt(2, Character.toLowerCase(c));
                }

                methodUsed = sb.toString();
                method = introspector.getMethod(clazz, methodUsed, params);
            }

            if (method != null) {
                /*
                 *  now, this has to return a boolean
                 */

                if (method.getReturnType() == Boolean.TYPE) {
                    return;
                }

                method = null;
            }
            /**
             * pass through application level runtime exceptions
             */
        } catch( RuntimeException e ) {
            throw e;
        } catch (Exception e) {
            rlog.error("PROGRAMMER ERROR : BooleanPropertyExector() : " + e, e);
        }
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy