Subversion Repositories mkgmap

Rev

Rev 2470 | View as "text/plain" | Blame | Compare with Previous | Last modification | View Log | RSS feed

/*
 * Copyright (C) 2012.
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 3 or
 * version 2 as published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful, but
 * WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * General Public License for more details.
 */


package uk.me.parabola.mkgmap.osmstyle.function;

import static uk.me.parabola.mkgmap.osmstyle.eval.NodeType.FUNCTION;

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Set;

import uk.me.parabola.mkgmap.osmstyle.eval.ValueOp;
import uk.me.parabola.mkgmap.reader.osm.FeatureKind;
import uk.me.parabola.mkgmap.reader.osm.Node;
import uk.me.parabola.mkgmap.reader.osm.Relation;
import uk.me.parabola.mkgmap.reader.osm.Way;
import uk.me.parabola.mkgmap.scan.SyntaxException;

/**
 * The interface for all functions that can be used within a style file.<br>
 * The input parameter of a function is one element. The resulting value is a
 * string which can carry number values.
 * @author WanMil
 */

public abstract class StyleFunction extends ValueOp {

        protected int reqdNumParams = 0;
        protected List<String> params;
        protected FeatureKind kind;

        public StyleFunction(String value) {
                super(value);
                setType(FUNCTION);
        }

        public void setParams(List<String> params, FeatureKind kind) {
                if (params.size() != reqdNumParams)
                        throw new SyntaxException(String.format("Function %s takes %d parameters, %d given", getName(), reqdNumParams, params.size()));
                this.params = new ArrayList<>(params);
                this.kind = kind;
        }

        /**
         * Retrieves if the function accepts {@link Node} objects as input parameter.
         *
         * @return {@code true} {@link Node} objects are supported; {@code false} .. are not supported
         */

        public boolean supportsNode() {
                return false;
        }

        /**
         * Retrieves if the function accepts {@link Way} objects as input parameter.
         *
         * @return {@code true} {@link Way} objects are supported; {@code false} .. are not supported
         */

        public boolean supportsWay() {
                return false;
        }

        /**
         * Retrieves if the function accepts {@link Relation} objects as input parameter.
         *
         * @return {@code true} {@link Relation} objects are supported; {@code false} .. are not supported
         */

        public boolean supportsRelation() {
                return false;
        }

        /**
         * Retrieves the function name. This is the part without function brackets (). It is case sensitive but should be lower
         * case.
         *
         * @return the function name (e.g. length for length())
         */

        public String getName() {
                return getKeyValue();
        }

        @Override
        public String toString() {
                return getName() + "()";
        }

        /**
         * @return the tag keys evaluated in this function.
         */

        public Set<String> getUsedTags() {
                return Collections.emptySet();
        }

        /**
         *
         * @return an estimate for the complexity of this function, a value >= 1 and <= 10
         */

        public int getComplexity() {
                return 1;
        }
}