/*******************************************************************************
* LastCalc - The last calculator you'll ever need
* Copyright (C) 2011, 2012 Uprizer Labs LLC
*
* This program is free software: you can redistribute it and/or modify it
* under the terms of the GNU Affero 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 Affero General Public License for more
* details.
******************************************************************************/
package com.lastcalc.parsers.collections;
import java.util.*;
import com.google.common.collect.Lists;
import org.jscience.mathematics.number.LargeInteger;
import com.lastcalc.TokenList;
import com.lastcalc.parsers.Parser;
public class GetFromListOrMap extends Parser {
private static TokenList template = TokenList.createD("get", Object.class, "from",
Lists.newArrayList(Map.class, List.class));
/**
*
*/
private static final long serialVersionUID = 5755928813441453688L;
@Override
public ParseResult parse(final TokenList tokens, final int templatePos) {
final Object toGet = tokens.get(templatePos + 1);
if (tokens.get(templatePos + 3) instanceof Map) {
final Map<Object, Object> map = (Map<Object, Object>) tokens.get(templatePos + 3);
final Object got = map.get(toGet);
if (got != null)
return ParseResult.success(tokens.replaceWithTokens(templatePos, templatePos + template.size(), got));
else
return ParseResult.success(tokens.replaceWithTokens(templatePos, templatePos + template.size(), false));
} else if (tokens.get(templatePos + 3) instanceof List) {
final List<Object> list = (List<Object>) tokens.get(templatePos + 3);
if (toGet instanceof LargeInteger) {
final int ix = ((LargeInteger) toGet).intValue();
if (ix < 0 || ix >= list.size())
return ParseResult.fail();
else
return ParseResult.success(tokens.replaceWithTokens(templatePos, templatePos + template.size(),
list.get(ix)));
} else
return ParseResult.fail();
} else
return ParseResult.fail();
}
@Override
public TokenList getTemplate() {
return template;
}
@Override
public int hashCode() {
return "GetFromListOrMap".hashCode();
}
@Override
public boolean equals(final Object obj) {
return obj instanceof GetFromListOrMap;
}
}