/* * This file is part of the X10 project (http://x10-lang.org). * * This file is licensed to You under the Eclipse Public License (EPL); * You may not use this file except in compliance with the License. * You may obtain a copy of the License at * http://www.opensource.org/licenses/eclipse-1.0.php * * This file was originally derived from the Polyglot extensible compiler framework. * * (C) Copyright 2000-2007 Polyglot project group, Cornell University * (C) Copyright IBM Corporation 2007-2012. */ package polyglot.util; import java.util.*; /** * This subclass of TransformingList applies the transformation to each * element of the underlying list at most once. */ public class CachingTransformingList<S,T> extends TransformingList<S,T> { protected ArrayList<T> cache; public CachingTransformingList(Collection<S> underlying, Transformation<S,T> trans) { this(new ArrayList<S>(underlying), trans); } public CachingTransformingList(List<S> underlying, Transformation<S,T> trans) { super(underlying, trans); cache = new ArrayList<T>(Collections.<T>nCopies(underlying.size(), null)); } public T get(int index) { T o = cache.get(index); if (o == null) { o = trans.transform(underlying.get(index)); cache.set(index, o); } return o; } }