/* * sulky-modules - several general-purpose modules. * Copyright (C) 2007-2011 Joern Huxhorn * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * 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 Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. */ /* * Copyright 2007-2011 Joern Huxhorn * * 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 de.huxhorn.sulky.conditions; import java.util.ArrayList; import java.util.List; /** * Returns false if any of it's sub-conditions return false. */ public class And implements ConditionGroup { private static final long serialVersionUID = -8906390235171353778L; private List<Condition> conditions; public And() { this(null); } public And(List<Condition> conditions) { this.conditions = conditions; } public List<Condition> getConditions() { return conditions; } public void setConditions(List<Condition> conditions) { this.conditions = conditions; } /** * Returns false if any of the contained conditions is false. * * This implies that it returns true if the contained conditions are either null or empty. * * @param element the object to be evaluated. * @return false if any of the contained conditions is false. */ public boolean isTrue(Object element) { if(conditions != null) { for(Condition condition : conditions) { if(!condition.isTrue(element)) { return false; } } } return true; } public boolean equals(Object o) { if(this == o) return true; if(o == null || getClass() != o.getClass()) return false; final And and = (And) o; return !(conditions != null ? !conditions.equals(and.conditions) : and.conditions != null); } public int hashCode() { return (conditions != null ? conditions.hashCode() : 0); } public And clone() throws CloneNotSupportedException { And result = (And) super.clone(); if(result.conditions != null) { List<Condition> clonedConditions = new ArrayList<>(conditions.size()); for(Condition condition : result.conditions) { clonedConditions.add(condition.clone()); } result.conditions = clonedConditions; } return result; } public String toString() { StringBuilder result = new StringBuilder(); if(conditions == null || conditions.size() == 0) { result.append("true"); } else { result.append("("); boolean first = true; for(Condition condition : conditions) { if(first) { first = false; } else { result.append(" && "); } result.append(condition); } result.append(")"); } return result.toString(); } }