/* * Copyright 2010 Sun Microsystems, Inc. All Rights Reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. * * This code 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 * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, * CA 95054 USA or visit www.sun.com if you need additional information or * have any questions. */ package org.visage.runtime.sequence; import org.visage.runtime.VisageObject; public abstract class BoundForOverSingleton<T, PT> extends BoundFor<T, PT> { public BoundForOverSingleton(VisageObject container, int forVarNum, int inductionSeqVarNum, boolean dependsOnIndex) { super(container, forVarNum, inductionSeqVarNum, dependsOnIndex); } protected void restoreValidState(int lowPart, int highPart) { //TODO: This maintains existing semantics -- remove for better performance inWholesaleUpdate = true; for (int ipart = lowPart; ipart < highPart; ++ipart) { get(ipart); } inWholesaleUpdate = false; } protected int decacheLengths() { int previousSize = sizeAtLastTrigger; sizeAtLastTrigger = numParts; return previousSize; } protected int cumLength(int ipart) { return ipart; } protected int cachedCumLength(int ipart) { return ipart; } public int size() { initializeIfNeeded(); return numParts; } public T get(int index) { initializeIfNeeded(); if (index < 0 || index >= numParts) { return null; } else { VisageForPart part = getPart(index); T res = (T) part.get$(partResultVarNum); return res; } } }