Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance. Project price only 1 $
You can buy this project and download/modify it how often you want.
/**
* MVEL 2.0
* Copyright (C) 2007 The Codehaus
* Mike Brock, Dhanji Prasanna, John Graham, Mark Proctor
*
* 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 org.mvel2.templates.res;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import org.mvel2.CompileException;
import org.mvel2.MVEL;
import org.mvel2.integration.VariableResolverFactory;
import org.mvel2.integration.impl.MapVariableResolverFactory;
import org.mvel2.templates.TemplateRuntime;
import org.mvel2.templates.TemplateRuntimeError;
import org.mvel2.templates.util.ArrayIterator;
import org.mvel2.templates.util.TemplateOutputStream;
import org.mvel2.util.ParseTools;
public class ForEachNode extends Node {
public Node nestedNode;
private String[] item;
private String[] expression;
private char[] sepExpr;
public ForEachNode(int begin, String name, char[] template, int start, int end) {
super(begin, name, template, start, end);
configure();
}
public Node getNestedNode() {
return nestedNode;
}
public void setNestedNode(Node nestedNode) {
this.nestedNode = nestedNode;
}
public boolean demarcate(Node terminatingnode, char[] template) {
nestedNode = next;
next = terminus;
sepExpr = terminatingnode.getContents();
if (sepExpr.length == 0) sepExpr = null;
return false;
}
public Object eval(TemplateRuntime runtime, TemplateOutputStream appender, Object ctx, VariableResolverFactory factory) {
Iterator[] iters = new Iterator[item.length];
Object o;
for (int i = 0; i < iters.length; i++) {
if ((o = MVEL.eval(expression[i], ctx, factory)) instanceof Iterable) {
iters[i] = ((Iterable) o).iterator();
} else if (o instanceof Object[]) {
iters[i] = new ArrayIterator((Object[]) o);
} else {
throw new TemplateRuntimeError("cannot iterate object type: " + o.getClass().getName());
}
}
Map locals = new HashMap();
MapVariableResolverFactory localFactory = new MapVariableResolverFactory(locals, factory);
int iterate = iters.length;
while (true) {
for (int i = 0; i < iters.length; i++) {
if (!iters[i].hasNext()) {
iterate--;
locals.put(item[i], "");
} else {
locals.put(item[i], iters[i].next());
}
}
if (iterate != 0) {
nestedNode.eval(runtime, appender, ctx, localFactory);
if (sepExpr != null) {
for (Iterator it : iters) {
if (it.hasNext()) {
appender.append(String.valueOf(MVEL.eval(sepExpr, ctx, factory)));
break;
}
}
}
} else break;
}
return next != null ? next.eval(runtime, appender, ctx, factory) : null;
}
private void configure() {
ArrayList items = new ArrayList();
ArrayList expr = new ArrayList();
int start = cStart;
for (int i = start; i < cEnd; i++) {
switch (contents[i]) {
case '(':
case '[':
case '{':
case '"':
case '\'':
i = ParseTools.balancedCapture(contents, i, contents[i]);
break;
case ':':
items.add(ParseTools.createStringTrimmed(contents, start, i - start));
start = i + 1;
break;
case ',':
if (expr.size() != (items.size() - 1)) {
throw new CompileException("unexpected character ',' in foreach tag", contents, cStart + i);
}
expr.add(ParseTools.createStringTrimmed(contents, start, i - start));
start = i + 1;
break;
}
}
if (start < cEnd) {
if (expr.size() != (items.size() - 1)) {
throw new CompileException("expected character ':' in foreach tag", contents, cEnd);
}
expr.add(ParseTools.createStringTrimmed(contents, start, cEnd - start));
}
item = new String[items.size()];
int i = 0;
for (String s : items)
item[i++] = s;
expression = new String[expr.size()];
i = 0;
for (String s : expr)
expression[i++] = s;
}
}