com.frank.search.solr.core.query.DivideFunction.java Source code

Java tutorial

Introduction

Here is the source code for com.frank.search.solr.core.query.DivideFunction.java

Source

/*
 * Copyright 2012 - 2013 the original author or authors.
 *
 * 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.frank.search.solr.core.query;

import org.springframework.util.Assert;

import java.util.Arrays;

/**
 * Implementation of {@code div(x,y)}
 * 
 * @author Christoph Strobl
 * @since 1.1
 */
public class DivideFunction extends AbstractFunction {

    private static final String OPERATION = "div";

    private DivideFunction(Object dividend, Object divisor) {
        super(Arrays.asList(dividend, divisor));
    }

    /**
     * creates new {@link DivideFunction.Builder} for dividing value in field with given name
     *
     * @param field must not be null
     * @return
     */
    public static Builder divide(Field field) {
        Assert.notNull(field, "Field cannot be 'null' for divide function.");

        return divide(field.getName());
    }

    /**
     * creates new {@link DivideFunction.Builder} for dividing value in field with given name
     *
     * @param fieldname must not be empty
     * @return
     */
    public static Builder divide(String fieldname) {
        Assert.hasText(fieldname, "Fieldname cannot be 'empty' for divide function.");

        return new Builder(fieldname);
    }

    /**
     * creates new {@link DivideFunction.Builder} for dividing given value
     *
     * @param dividend
     * @return
     */
    public static Builder divide(Number dividend) {
        return new Builder(dividend);
    }

    /**
     * creates new {@link DivideFunction.Builder} for dividing value calculated by given {@link Function}
     * 
     * @param dividend
     * @return
     */
    public static Builder divide(Function dividend) {
        return new Builder(dividend);
    }

    @Override
    public String getOperation() {
        return OPERATION;
    }

    public static class Builder {

        private Object dividend;

        public Builder(Object dividend) {
            Assert.notNull(dividend, "Dividend must not be 'null'");

            this.dividend = dividend;
        }

        /**
         * @param divisor must not be null
         * @return
         */
        public DivideFunction by(Number divisor) {
            return by((Object) divisor);
        }

        /**
         * @param divisor must not be null
         * @return
         */
        public DivideFunction by(Function divisor) {
            return by((Object) divisor);
        }

        /**
         * @param fieldname must not be empty
         * @return
         */
        public DivideFunction by(String fieldname) {
            Assert.hasText(fieldname, "Fieldname for devide function must not be 'empty'.");

            return by((Object) fieldname);
        }

        /**
         * @param field must not be null
         * @return
         */
        public DivideFunction by(Field field) {
            Assert.notNull(field, "Field must not be 'null'.");

            return by(field.getName());
        }

        private DivideFunction by(Object divisor) {
            Assert.notNull(divisor, "Cannot divide by 'null'.");

            return new DivideFunction(dividend, divisor);
        }
    }

}